METHOD FOR CHECKING MODULAR MULTIPLICATION 



Background of the Invention 

The present application is directed to a method and apparatus for performing encryption 
and decryption. The application discloses several inventions relating to an overall system for the 
5 use of exponentiation modulo N as a mechanism for carrying out the desired cryptological goals 
and functions in a rapid, efficient, accurate and reliable manner. A first part of the disclosure is 
related to the construction of a method and its associated apparatus for carrying out modular 
multiplication. A second part of the disclosure is directed to an improved apparatus for carrying 
out modular multiplication through the partitioning of the problem into more manageable pieces 
10 and thus results in the construction of individual identical (if so desired) Processing Elements. A 

1 third part of the disclosure is directed to the utilization of the resulting series of Processing 
^ Elements in a pipelined fashion for increased speed and throughput. A fourth part of the 

2 disclosure is directed to an apparatus and method for calculating a unique inverse operation that 
1 is desirable as an input step or stage to the modular multiplication operation. A fifth part of the 
^=15 disclosure is directed to the use of the modular multiplication system described herein in its 

originally intended function of performing an exponentiation operation. A sixth part of the 
^ disclosure is directed to the use of the Chinese Remainder Theorem in conjunction with the 

3 exponentiation operation. A seventh part of the this disclosure is directed to the construction and 
7i utilization of checksum circuitry which is employed to insure reliable and accurate operation of 

20 the entire system. The present application is particularly directed the invention described in the 
seventh part of the disclosure. 

More particularly, the present invention is directed to circuits, systems and methods for 
multiplying two binary numbers having up to n bits each with the multiplication being modulo, A'^ 
an odd number. In particular, the present invention partitions one of the factors into m blocks 
25 with k bits in each block with the natural constraint that mk>n-^ 2. Even more particularly, the 
present invention is directed to multiplication modulo N when the factors being multiplied have 
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a large number of bits. The present invention is also particularly directed to the use of the 
modular multiplication function hardware described herein in the calculation of a modular 
exponentiation function for use in cryptography. Ancillary functions, such as the calculation of a 
convenient inverse and a checksum mechanism for the entire apparatus are also provided herein. 
The partitioning employed herein also results in the construction of Processing Elements which 
can be cascaded to provide significant expansion capabilities for larger values of N, This, in turn, 
leads to a modality of Processor Element use in a pipelined fashion. The cascade of Processor 
Elements is also advantageously controllable so as to effectively partition the Processor Element 
chain into separate pieces which independently work on distinct and separate factors of N. 

Those wishing an optimal understanding from this disclosure should appreciate at the 
outset that the purpose of the methods and circuits shown herein is the performance of certain 
arithmetic functions needed in modem cryptography and that these operations are not standard 
multiplication, inversion and/or exponentiation, but rather are modulo N operations. The fact 
that the present application is directed to modular arithmetic circuits and methods, as opposed to 
standard arithmetic operations, is a fact which would be best to keep firmly in mind, particularly 
since modular arithmetic, with it implied division operations, is much more difficult to perform 
and to calculate, particularly where exponentiation modulo N is involved. 

In a preferred system for implementation which takes advantage of certain aspects of the 
present invention, this application is also directed to a circuit and method of practice in which an 
adder array and a multiplier array are effectively partitioned into in a series of nearly identical 
processor elements with each processor element (PE) in the series operating on a sub-block of 
data. The multiplier array and adder array are thus partitioned. Thus, having recognized the 
ability to reconfigure the generic structure into a plurality of serially connected processor 
elements, the present invention is also directed to a method of operation in which each processor 
element operates as part of a pipeline over a plurality of operational cycles. The pipelining mode 
of operation is even further extended to the multiplication of a series of numbers in a fashion in 
which all of the processor elements are continuously actively generating results. 
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The multiplication of binary numbers module is an important operation in modem, 
public-key cryptography. The security of any cryptographic system which is based upon the 
multiplication and subsequent factoring of large integers is directly related to the size of the 
numbers employed, that is, the number of bits or digits in the number. For example, each of the 
two multiplying factors may have up to 1 ,024 bits. However, for cryptographic purposes, it is 
necessary to carry out this multiplication modulo a number N. Accordingly, it should be 
understood that the multiplication considered herein multiplies two n bit numbers to produce a 
_ result with n bits or less rather than the usual 2n bits in conventional multiplication. 

However, even though there is a desire for inclusion of a large number of bits in each 
factor, the speed of calculation becomes significantly slower as the number of digits or bits 
increase. However, for real-time cryptographic purposes, speed of encryption and decryption are 
important concems. In particular, real-time cryptographic processing is a desirable result. 

Different methods have been proposed for carrying out modular multiplication. In 
particular, in an article appearing in "The Mathematics of Computation," Vol. 44, No. 170, April 
1995, pp. 519-521, Peter L. Montgomery describes an algorithm for "Modular Multiplication 
without Trial Division." However, this article describes operations that are impractical to 
implement in hardware for a large value ofN, Furthermore, the method described by 
Montgomery operates only in a single phase. In contrast, the system and method presented 
herein partitions operational cycles into two phases. From a hardware perspective, the 
partitioning provides a mechanism for hardware sharing which provides significant advantages. 

Summarv of the Invention 

In accordance with a preferred embodiment of the present invention, an initial zero value 
is stored in a result register Zo. The integers A and B which are to be multiplied using the present 
process are partitioned into m blocks with k bits in each block. The multiplication is carried out 
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modulo A^. Additionally, the value R is set equal to 2*. In this way, the integer^ is representable 
as ^ = Am-iR"'^ + • " + ^2^^+ AiR+ Aq, This is the partitioning of the integer A into m blocks. 

In one embodiment of the present invention, a method and circuit are shown for 
computing a function Z ^ f(A, B) = AB 2"'"* mod N. Later , it will be shown how this function is 
used to calculate AB mod itself. 

The system, methods, and circuits of the present invention are best understood in the 
context of the underlying algorithm employed. Furthermore, for purposes of understanding this 
algorithm, it is noted that modular computation is carried out modulo N, which is an odd number 
and n is the number of bits in the binary representation of N, Additionally, No represents the least 
significant k bits of A^. Also, a constant s is employed which is equal to -1/No mod 
R = 1/(R - No) mod R, With this convention, the algorithm is expressed in pseudo code as 
follows: 

Zo = 0 

for z = 0 to m - 7 

Xi= Zi + AiB 

yi = s Xi,o mod R (x uo is the least significant k bits of Xi) 

Zi.i^{X,^y,N)IR 

end. 

There are two items to note in particular about this method for carrying out modulo N 
multiplication. The first thing to note is that the multiplication is based upon a partitioning of 
one of the factors into sub-blocks with k bits in each block. This greatly simplifies the size of 
multiplier arrays which need to be constructed. It furthermore creates a significant degree of 
parallelism which permits the multiplication operation be carried out in a much shorter period of 
time. The second item to note is that the partitioning also results in the splitting of the process 
not only into a plurality of aw cycles, but also, splits the method into two phases that occur in each 
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cycle. In the first phase (X-phase), the values Xi mdyt are computed. In the second phase 
(Z-phase), the intermediate result value Z,>y is calculated. It should be noted that, in the 
calculation ofXi and in the calculation of Z,>y, there is an addition operation and a multiplication 
operation. This fact allows the same hardware which performs the multiplication and addition in 
5 each of these steps to be shared rather than duplicated. With respect to the division by R in the 

formation of Z/+/, it is noted that this is accomplishable by simply discarding the low order k bits. 
Other advantages of this structure will also become apparent. 

The output of the above hardware and method produces the product AB 2"'"* mod A^. To 
produce the more desirable result AB mod A^, the method and circuit employed above is used a 

10 second time. In particular, the original output from this circuit is supplied to one of its input 

registers with the other register containing the factor 2^^"* mod N, This factor eliminates the first 

t factor of 2'"'^ added during the first calculation and also cancels the additional factor of 2 '"* 

;l included when the circuit is run the second time. This produces the result AB mod N, 

"I 

For those who wish to practice the processes of the present invention via software, it is 
^ 5 noted that the algorithm for multiplication provided above is readily implementable in any 
^ standard procedure-based programming language with the resulting code, in either source or 

object form, being readily storable on any convenient storage medium, including, but certainly 
3 not limited to, magnetic or optical disks. This process is also eminently exploitable along with 

2 the use of the exponentiation processes described below, including processes for exponentiation 

20 based on the Chinese Remainder Theorem. 

In the process described above it is noted that one of the process inputs is the variable *'s". 
This value is calculated as a negative inverse modulo R. In order to facilitate the generation of 
this input signal, a special circuit for its generation is described herein. This circuit also takes 
advantage of existing hardware used in other parts of a processing element. In particular, it 
25 forms a part of the rightmost processor element in a chain. 
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Note that, in the calculation shown above for X/ and Z/, these are more than n bit 
numbers. Accordingly, the multiplication and addition operations are carried out in relatively 
large circuits which are referred to herein as multiplier and adder arrays. In accordance with a 
preferred method of practicing the present invention, the adder array and multiplier array are split 
5 into sub-blocks. While this partitioning of hardware may be done using any convenient number 
of blocks, partitioning into blocks capable of processing k bits at a time is convenient. Thus, in 
the preferred embodiment, instead of employing one large multiplier array for processing two 
numbers having n + 1 bits and k bits; with n being much greater than k, a plurality of separate k 
bit by k bit multipliers are employed. Additionally, it is noted that partitioning into, processor 
10 element sub-blocks, while useful in and of itself particularly for circuit layout efficiency, also 
ultimately makes it possible to operate the circuit in several pipelined modes. 

I In a first pipelined mode, the circuit is operated through a plurality of cycles, m, in which 

;f adjacent processor elements are operated in alternate phases. That is, in a first pipelined mode, if 

5 a processor element is in the ^-phase, its immediate neighbors are operating in the Z-phase, and 

jl 5 vice versa. In a second pipelined mode, the pipelined operation is continued but with new entries 
' in the input registers (A and B) which now are also preferably partitioned in the same manner as 

^ the multiplier and adder arrays. 

f Since n is generally much greater than k (1,024 as compared to 32, for example) and since 

1 carry propagation through adder stages can contribute significantly to processing delays, the 

20 partitioning and pipelining together eliminate this source of circuit delay and the corresponding 

dependence of circuit operation times on the significant parameter n whose size, in cryptographic 

contexts, determines the difficulty of unwarranted code deciphering. 



The pipelined circuit of the present invention is also particularly useful in carrying out 
exponentiation modulo A^, an operation that is also very useful in cryptographic applications. 
25 Such an operation involves repeated multiplication operations. Accordingly, even though 



POU920000124US1 



-6" 




pipelining may introduce an initial delay, significant improvements in performance of 
exponentiation operations are produced. 

In one embodiment found within the disclosure herein it has been noted that the chaining 
together of individually operating Processing Elements introduces an addition operation in a 
5 critical timing path, that is, into a path whose delayed execution delays the whole process. The 
present invention provides an improvement in the design of the individual Processing Elements 
through the placement of this addition operation in an earlier portion of the Processing Element's 
operation. In doing so, however, new control signals are also provided to make up for the fact 
that some signals in some of the Processing Elements are not yet available at this earlier stage 
10 and accordingly are, where convenient, provided from operations occurring or which have 
already occurred in adjacent Processing Elements. 

2 The Processing Elements used herein are also specifically designed so that they may 

J function in different capacities. In particular, it is noted that the rightmost Processing Element 

J performs some operations that are unique to its position as the lower order Processing Element in 

^15 the chain. Likewise the leftmost element has a unique role and can assume a simpler form. 

^ However, the Processing Elements employed herein are also specially designed and constructed 

T so as to be able to adapt to different roles in the chain. In particular, the middle Processing 

f Element is controllable so that it takes on the functional and operational characteristics of a 

3 rightmost Processing Element. In this way the entire chain is partitionable so that it forms two 
20 (or more, if needed) separate and independent chains operating (in preferred modalities) on 

factors of the large odd integer A^. 

While an intermediate object of the present invention is the construction of a modular 
multiplication engine, a more final goal is providing an apparatus for modular exponentiation. In 
the present invention this is carried out using the disclosed modular multiplier in a repeated 
25 fashion based on the binary representation of the exponent. A further improvement on this 

process involves use of the Chinese Remainder Theorem for those parts of the exponentiation 
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operation in which the factors of N are known. The capability of the Processing Element chain 
of the present invention to be partitioned into two portions is particularly useful here since each 
portion of the controllably partitioned chain is able to work on each of the factors of in an 
independent and parallel manner. 

5 Since one wishes to operate computational circuits at as high a speed as possible and 

since this can some times lead to erroneous operations, there is provided a challenge in how to 
detect errors when the operations being performed are not based on standard arithmetic, but are 
rather based on modular arithmetic (addition, subtraction, inversion and multiplication and 
exponentiation). However, the present invention solves this problem through the use of circuits 

10 and methods which are not only consonant with the complicating requirements of modular 

arithmetic operations but which are also capable of being generated on the fly with the addition 
of only a very small amount of additional hardware and with no penalty in time of execution or 
throughput. 

Accordingly, it is seen that it is an object of the present invention to produce a multiplier 
1 5 for multiplying two large integers modulo N. 

It is yet another object of the present invention to improve the performance and 
capabilities of cryptographic circuits and systems. 

It is a still further object of the present invention to create a multiplier circuit which 
operates at high speed. 

20 It is yet another object of the present invention to create a multiplier circuit which 

performs multiplication modulo without having to perform division operations. 

It is also an object of the present invention to provide a multiplier which is scaleable for 
various values of and n. 
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It is also another object of the present invention to provide a method for computing a 
product of two integers modulo 7^ in a multi-phase process which permits sharing of hardware 
circuitry across the two phases. 

It is yet another object of the present invention to provide a system and method in which 
the factors are partitioned into a plurality of m sub-blocks with each sub-block having k bits, 
whereby values for m and k are selectable so as to provide additional flexibility in hardware 
structure. 

It is also another object of the present invention, to increase the speed of multiplication 
calculations in cryptographic processes. 

It is also an object of the present invention to provide an implementation for a multiplier 
circuit which uses macro components as building blocks so as to avoid the costs associated with 
custom design. 

It is also an object of the present invention to provide a design which is flexible and 
scaleable. 

It is also an object of the present invention to provide a word-oriented, as opposed to a 
bit-oriented, multiplication system and circuit. 

It is a still further object of the present invention to construct a circuit for multiplication 
modulo which comprises a plurality of nearly identical processor elements. 

It is yet another object of the present invention to partition the multiplication of an « bit 
number into a plurality of pieces for quasi-independent calculation. 
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It is still another object of the present invention to operate the circuit herein in a pipelined 

mode. 

It is an even further object of the present invention to operate the circuit herein so as to 
process sequences of distinct operands (factors) in a pipelined mode. 

It is yet another object of the present invention to improve the performance of a sequence 
of chained Processing Elements by removing addition functions from critical paths. 

It is a still further object of the present invention to operate the circuit herein so as to 
process sequences of identical or repeated operands in a pipelined mode, as for example, in the 
calculation of the exponential function modulo N, 

It is yet another object of the present invention to increase the speed of exponentiation 
operations in cryptographic processes. 

It is a still further object of the present invention to provide Processing Elements v^hose 
character as beginning, middle or end units in the chain may be controlled so as to enable the 
partitioning of the chain into a plurality of sub-chains each of which is capable of independent 
parallel processing based on a factor of N, 

It is also an object of the present invention to provide a mechanism for calculating an 
inverse operation which is useful as an input to the method of modular multiplication employed 
herein. 

It is yet another object of the present innovation to provide an apparatus and method for 
generating useful checksums which are useful for indicating that the system has operated in a 
proper fashion and has produced no errors. 
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It is a still further object of the present invention to provide a checksum circuit and 
method which is consonant with modular arithmetic. 

It is also an object of the present invention to provide an engine which is capable of data 
encryption through the use of exponentiation modulo N, a large prime or the product of two large 
primes. 

It is a further object of the present invention to provide an engine which is capable of data 
decryption through the use of exponentiation modulo N. 

It is yet another object of the present invention to employ the Chinese Remainder 
Theorem to facilitate the exponentiation operation modulo N when factors for N are known. 

It is also an object of the present invention to provide an encryption/decryption engine 
which is capable of operating in the mode of public key cryptographic systems. 

It is also an object of the present invention to provide an engine which is capable of 
generating and receiving documents having coded digital signatures. 

It is also an object of the present invention to provide an engine which is capable of 
generating keys to be exchanged between any two users for data encryption and decryption. 

It is also an object of the present invention to produce a high-speed, high-performance 
cryptographic engine. 

Lastly, but not limited hereto, it is an object of the present invention to provide a 
cryptographic engine for encryption and for decryption which can be included as part of a larger 
processing system and therefore possesses communication capabilities for the transfer of data and 
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command information from other parts of a larger scale data processing system with which the 
present engine is coupled. 

The recitation herein of a list of desirable objects which are met by various embodiments 
of the present invention is not meant to imply or suggest that any or all of these objects are 
present as essential features, either individually or collectively, in the most general embodiment 
of the present invention or in any of its more specific embodiments. 

Description of the Drawings 

The subject matter which is regarded as the invention is particularly pointed out and 
distinctly claimed in the concluding portion of the specification. The invention, however, both as 
to organization and method of practice, together with the further objects and advantages thereof, 
may best be understood by reference to the following description taken in connection with the 
accompanying drawings in which: 

Figure 1 is a block diagram illustrating the circuits employed in the method and system 
for multiplication modulo described herein ; 

Figure 2 is a block diagram identical to Figure 1 except more particularly showing those 
data flow paths which are active during a first or X-phase of calculation; 

Figure 3 is a block diagram similar to Figures 1 and 2 except more particularly showing 
those data flow paths which are active during the second or Z-phase of calculation,; 

Figure 4 is a block diagram of the rightmost processing element in a series of processing 
elements in a partitioned embodiment of the circuit of Figure 1; 
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Figure 4A is a block diagram similar to Figure 4 but which illustrates an alternate 
multiplier- to-adder connection; 

Figure 5 is a block diagram illustrating one of a plurality of identical processing elements 
which are configurable as a series of processor elements capable of performing the same 
operation as the circuit shown in Figure 1 ; 

Figure 5 A is a block diagram similar to Figure 5 but which also illustrates an alternate 
multiplier-to-adder connection; 

Figure 6 is a block diagram illustrating the form of a processing element that could 
expeditiously be employed as the last or leftmost processor element in a series of processor 
elements for carrying out the same calculations as the circuit of Figure 1; 

Figure 7 is a block diagram illustrating how the processor elements described in Figures 
4, 5, and 6 are connected to produce the same results as the circuit shown in Figure 1; 

Figure 8 is a block diagram illustrating the logical connection of processor elements over 
time with particular reference to register storage and the X and Z phases of operation; 

Figure 9 is a block diagram illustrating the use of processor elements in a pipelined 
fashion; 

Figure 10 is a block diagram illustrating a typical processor element as configured for use 
in a pipelining mode; 

Figure 1 1 is a block diagram similar to Figure 10 but more particularly illustrating a 
processor element to be used in the rightmost or lower order position; 
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Figure 12 is a block diagram similar to Figure 8 but more particularly showing a variation 
in the utilization of pipelining to speed up processing time by eliminating an adder from a critical 
path; 

Figure 1 3 is a block diagram illustrating an improved rightmost processor element in 
which an adder in a critical path has been moved to improve performance; 

Figure 14 is a block diagram similar to Figure 13 but more particularly illustrating a 
typical processor element for use in an improved pipeline operation; 

Figure 15 is a block diagram illustrating a preferred design for the leftmost processor 
element in an improved pipelined configuration; 

Figure 16 illustrates processor element utilization in pipelined operations; 

Figure 17 is a block diagram illustrating a circuit for calculating the negative modular 
inverse of a number; 

Figure 1 8 is a flow chart illustrating a method for using circuits which implement 
modular multiplication in a fashion so as to further implement the exponentiation function; 

Figure 19 is a flow chart similar to Figure 18 but exhibiting an alternative algorithm for 
implementing a modular exponentiation fiuiction; 

Figure 20 is a block diagram of a circuit for implementing either one of the algorithms 
shown in Figures 18 or 19; 
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Figure 21 is a block diagram illustrating public key encryption and decryption processes 
particularly as it employs exponentiation operations, and more particularly illustrates the 
presence of signal variables used for efficiency improvements; 

Figure 22 is an overall block diagram view illustrating one embodiment of a 
5 cryptographic engine constructed in accordance with the present invention; 

Figure 23 is a block diagram illustrating the inclusion of a checksum mechanism 
consonant with a modulo N multiplication system; 

Figure 24 is a block diagram illustrating generically applicable circuits for generating 
intermediate checksum values using modulo (R- 1) addition; 

40 Figure 25 is a block diagram illustrating circuits for performing checksum operations 

3 used in a final checksum comparison operation which provides error indications; and 

^ Figure 26 is a block diagram illustrating circuits for generating checksum variables to be 

compared using, pairs of modulo (R- 1) adders. 

3 Detailed Description of the Invention 

1 5 The structure and operation of the present invention is dependent upon the partitioning of 

one of the multiplying factors into a plurality of k bit- wide pieces. Thus, instead of representing 

a binary number ^ as at 2\ one of the multiplying factors in the present invention is 

represented instead in the form A^-i R"" ^+ . . . A2 R^ + Aj R+ Ao == S AjR\ where R = 2. In 

this representation, the number A is represented in block form where each of the m blocks 
20 includes k bits. That is, each A, represents an integer having k bits. 
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In the present system, multiplication modulo an odd number is a significant object. 
Also, for purposes of understanding the present invention, the symbol n is used to denote the 
number of bits in the binary representation for N, Also, for present purposes, it is assumed that 
the number A, as stored in Register A (reference numeral 10 in Figure 1), is the number that is 
5 partitioned into m blocks. In general, the number of blocks m is selected to be the smallest 
integer for which mk> n + 2, Additionally, it is understood that No represents the least 
significant k bits of the number A^. Likewise, the constant s is equal to the negative reciprocal of 
No taken modulo R (that is, -1/No mod R), 

From a mathematical point of view, the present applicants have employed an algorithm 
10 for which the input variables are the two numbers being multiplied, namely, A and 5, the modulo 
number A^, the constant s associated with A^, and the parameters m, k and R = 2*. The output of 
Q the function provided by the present invention Z is given by Z =f(A, B) = AB 2""^ mod N, The 

= procedure specified by applicants' method initializes the value Zq to be zero and, for the integer / 

] ranging from 0 to calculations are carried out to produce Xi andyi and Z/+;. The values for 

•-J15 Xi and yi are computed during a first operational phase of each one of m cycles. The value Z/ is 
" computed during a second phase of each cycle. The adders and multipliers used to calculate Xi 

iJl are "time shared" to also carry out the calculation needed to produce Z,. In particular, at each 

stage i , Xi is given by Z, + Ai B, At this stage, the value ofyi is also computed as the constant s 
1^ times the least significant k bits of Xi modulo R, If one represents the least significant k bits of 

^=-20 Xi as Xifi then j^; = s X/,o. This completes the operations that are carried out in a first phase 

(Jf-phase) during one of the cycles of the present process. In the second phase (Z-phase), an 
updated value for Z register (50 in Figure 1) is computed as yi N)/R, At the last stage of 
processing, the desired value of Z is present in the Z register. In particular, at this stage, Zm = AB 
2"'"* mod A^. At each stage (cycle), values for X.yi, and Z/ are stored for purposes of computation 
25 in subsequent steps. 

It is noted that if both input variables A and B have n+1 bits, the output of the fiinction 
provided by the present invention Z='f{A,B)=AB 2*'"^ mod N, for A^ being an n-b\i odd number, 
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has no more than n-\-l significant bits. That is, the output is less than 2""^'. The hardware circuit 
described herein takes as inputs A and B of n^l bits each and generates as output Z of bits. 

A hardware circuit for carrying out this process is illustrated in Figure 1 . In particular, 
5 the factor Aofn+1 bits, which is the factor which is treated as being in partitioned form, is 

stored in^ register (10), Multiplexor 1 1 supplies sequential blocks of A: bits from register 10 to 
multiplexor 3 1 , with 32 bits for illustration. Multiplexors 31,21, and 52 operate in 
conjunction with one another selecting one of two possible input values depending upon whether 
or not the circuit is operating in the X-phase or the Z-phase. Accordingly, during the first phase 
10 of its operation, multiplexor 1 1 provides the k bits in Ao^. In the first phase of the second cycle, 
the next k bits ^/ in ^ are supplied via multiplexor 1 1 . A sub-block of k bits from A is provided 
during the initial or X phase portion of each cycle. In the third cycle, multiplexor 11, therefore, 
provides the next k bits in A, namely, the bits denoted above and herein as A2. Accordingly, 
"2 multiplexor 1 1 is seen to operate selectively as a function of the cycle number (namely, cycles 0 

C35 through w-i). 

During the X-phase of each cycle, the value Ai is selected from the A Register (10) via 
multiplexor 1 1 and correspondingly multiplexor 21 selects the contents of the B Register (20). 
j Thus, in accordance with the present invention, the numbers to be multiplied are stored in 

^;!f registers 10 and 20. It does not matter which number is stored in which register. It is also noted 

j;^0 that, whether or not the circuit is operating in the initial X-phase or in the final Z-phase in each 
cycle, multiplexors 3 1 and 21 supply k bits and «+7 bits, respectively, to multiplier array 70 in 
each phase. It is thus seen that, during theX-phase, multiplexors 31 and 21 select contents from 
the B register and part of the A register. It is also noted that, in typical situations, the value of n 
is often around 512 or more and the value of k is approximately 32. Accordingly, it is seen that 
25 multiplier array 70 strikes a balance between 7 bit x « bit multiplication and full w bit x w bit 

multiplication. It is also noted that increases in the value of n are almost always, in practice, an 
increase by a factor of at least a power of 2. 
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As with any binary multiplier with inputs that are n+1 bits wide and k bits wide 
respectively, multiplier array 70 produces an output which is n-^l-^k bits wide. The lower order k 
bits from multiplier array 70 are supplied to adder 65 which is designed to add two k bit addends 
at a time. In this regard, it is noted that adder 65 is present in the circuit for computing yt. As 
5 such, and given that the value of j;, is dependent upon the last k bits of the value Xi which is a 
sum which has not yet been fully computed, it is necessary to perform this addition which is 
essentially the addition for the low order k bits of JC. The first addend comes from the rightmost 
k bits in the Z register as selected by multiplexor 52. These bits are added to the k bits in the 
rightmost portion of the product Ai B. The output of adder 65 is X/.o which is the least significant 
10 k bits of Xi = Zi 4- AiB, This output is stored in register 55 and is also supplied to multipKer 80 
which multiplies two k bit numbers together. This is not, however, a multiplication modulo N, 
The other factor supplied to multiplier 80 is the number s from the s register (60). Since this 
!j result is required modulo i?, only the rightmost k bits from multiplier 80 are supplied back to the 

4 y register (30) in this X-phase. The value stored in this register is used during the calculation 

J 5 carried out in the Z-phase as discussed below. 

. I 

The rest of the X-phase calculation is devoted to calculation of the high order n+1 bits of 
^ the sum Z/ + AiB. Multiplier 70 is configured as a circuit for multiplying together the bits from 

^ the B Register (20) and a sequence of m blocks of k bits each from selected k bit blocks Ai from 

3 the A register. Multiplication of two k bit numbers generally produces a number having 2k bits 

Jo and, in particular, this is the situation with respect to applicants' multiplier 80. However, it is 
noted that the calculation of y/ is computed modulo R, The modulo requirement of the 
computation is easily accomplished simply by returning only the rightmost k bits from the output 
of multiplier 80 to the input of the y Register (30). 

As pointed out above, multiplication of numbers generally produces outputs having bit 
25 lengths greater than either of the two input number bit lengths. In particular, with respect to 

multiplier 70, the output is considered to be n-^J+k bits in length. The low order (rightmost) k 
bit output is supplied from multiplier 70 to adder 65. However, each k bit block multiplication 
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carried out in multiplier array 70 produces 2k bits formed as a A: bit "result" and a k bit "carry" 
into the next position. The summation to produce the desired intermediate output At is carried 
out in adder 75 which adds together two portions, the first portion which is w+l bits long and the 
second portion which is only n^l-k bits long. The n+l-k bits represent the "carry" portion of 
5 the multiplication. Accordingly, the output of adder array 75 is the result of the high order n+1 
bits of AiB, This result is supplied directly to adder array 85 which adds to it a shifted value of Zi 
from Z register 50. And appropriately, this high order «+7 bits of Xi = Z/ + AiB is stored in Z 
register 50 in preparation for the Z-phase calculation. The low order k bits of Xi are stored in 
register 55 as described above. 

10 In the Z-phase of an operation cycle, multiplier array 70 and adders 75 and 85 are again 

employed except that now the inputs to multiplier array 70 are the contents of the y Register (30) 
, 3 as selected by multiplexor 3 1 . The other factor supplied to multiplier array 70 is the contents of 

"2 the A'^ register (40) which is selected during the Z-phase of an operation cycle by means of 

0 multiplexor 21 . As before, multiplier array 70 computes the product of an n+ 7 bit number and a 
ll 5 k bit number. Adder array 75 performs the natural addition operation associated with 

■ " multiplication in which there is an effective carry-like operation from one k bit subfield to the 

next k bit subfield. Accordingly, the output of adder array 75 during the Z-phase of operation is 

1 LI I 

Is, the high order n+7 bits of the product yiN, The addition of yiN and the value Xi together with its 

division by R in the present method is accomplished by discarding the low order k bits from the 
CSO output of adder 65 and storing only the high order n-^l bits from adder 85 to register 50. 

The differences in the Jf-phases and Z-phases of operation are more fully appreciated 
from an inspection of the differences between Figures 2 and 3. In particular. Figure 2 illustrates 
the active data flow paths that are present in the first or X phase of each operational cycle. 
Likewise, Figure 3 illustrates the data flow paths which are active during the second or a Z-phase 
25 of each operational cycle. The calculations that are carried out in the X-phases and Z-phases are 
repeated a total of m times with the final result Z^ being one of the desired results at the end of m 
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cycles of operation with each cycle including anX-phase and a Z-phase. At this stage of 
operation, the value present in Z register 50 is AB 2~"'^ mod A^. 

The circuit illustrated in Figures 1-3 is also capable of producing the multiplicative result 
AB mod A^. This is accomplished by first using the circuit shown to compute AB 2"'"* mod N 
and then by using the circuit again with either the AorB register being provided with the output 
from the first operational stage and multiplying this value by 2^""^ mod N. Since each operation 
of the circuit (through m cycles) introduces the factor of 2"'"^, the multiplication by 2^^"^ cancels 
the first factor 2"^"* introduced during the first stage of operation of the circuit and also cancels 
the other factor of 2~^^ introduced during the second multiplicative stage of operation. Thus, 
using two passes (two stages) with m cycles each through the circuit of Figures 1-3, the result ^5 
mod N is computed. For purposes of clarity and ease of understanding and description as used 
herein, an operational stage of the process of the present invention refers to m cycles of circuit 
operation following the loading of the factors into the A and B registers. 

The operation of the above circuit is perhaps more easily understood by means of the 
following example in which k = 3, R = 2\ N ^ 107 = + 5R + 3 = (I 5, 3) = (N2 ^ Nj , NoX No 
= 3,m = 3, s =-l/No mod R = 5, A = 83 = R^ + 2R + 3 ^ (I 2, 3), B = 70 = R' + OR 6 = 
(I, 0, 6), Decimal digits are employed here merely for the sake of example and for an easier 
understanding of the process. For a more detailed illustration, the decimal numbers may be 
represented as blocks containing 3 bits each. The process carried out by the circuit disclosed 
above occurs in three steps as follows (/ = 0, / = 7, and / = 2): 

Step 1. 

Xo = Zo'^ AoB - (3, 2, 2), yo = 2s mod R = 2 
yoN=(2.10,6) ^(3^ 2^ 6) 
Xo^yoN =(6,5.0) 
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Z,=(Xo + yoN)/R = (0. 6,5) 
Step 2. 



AiB = (2,0.12) = (2,1,4) 
Xi=Z,+A,B = (3,0,1), y,=s 
y,N=(5.25, 15) = (1,0,2,7) 
X,+y,N =(1,3,3,0) 
Z2 = (1, 3, 3) 



Step 3. 



A:B= = (1,0,6) 

X2 = Z2 + A:B = (2, 4, 1), y, = s = 5 

y2N=(5,25,15) = (l,0,2, 7) 

X2+y2N =(1,2,7,0) 

Z3 = (1, 2, 7) = 87 



87xR^ =AxB mod N= 32. 



Although it is the objective to compute AB mod N where AB and are all n bits long, for 
convenience, the process herein employs A, B, and Z registers that are n+1 bits or mk bits long. 
This avoids the necessity for checking the final and intermediate results to determine whether or 
not they are in fact greater than N. This aspect, for example, shows up in Step 2 in the example 
provided above. 

The present inventors have also recognized that, at least partly due to the typically large 
difference between the size of n and k, there is a certain disparity in processing that occurs in the 
construction of an « by A; multiplier. Accordingly, it is possible to partition the calculation 
carried out in the circuit shown in Figures 1-3. In particular, the circuit shown in Figure 1 is in 
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fact constructable in the form a plurality, <i + i, of processor elements (PE) which are connected 
together in a chained or cascaded fashion. Each of the processing elements is constructed in the 
same way. However, the processing element for the rightmost portion of the data, herein referred 
to as PEo, has a somewhat more complicated structure, as shown in Figure 4. A simpler circuit is 
employed for processing elements 1 through However, in preferred embodiments, the leftmost 
or last processor element PEa can in fact be constructed much more simply as shown in Figure 6. 
Accordingly, Figure 4 shows a structure for a processing element circuit for the rightmost portion 
of the data. Figure 5 illustrates a circuit for a processing element which is usable in a repeated 
fashion which utilizes as many individual processing elements as necessary and thus, illustrating 
the scalability aspects of the present invention. Lastly, Figure 6 illustrates a preferred, simplified 
embodiment for the last or leftmost processing element. 

For purposes of understanding and appreciating the present invention, the registers Ro 
through Rd, as illustrated in Figures 4, 5, and 6, are not considered as a part of the processing 
elements per se but rather are best understood as part of a separate, partitioned register structure. 
It is these registers that contain the desired resuhs of the modulo multiplication operation. 
These registers thus serve the same function as the Z register in Figure 1. 

With specific reference to Figure 4, it is seen that multiplexor 193 operates during the 
X-phase to supply a 2k bit augend to adder 1 85. During the first or X-phase of operation, 
multiplexor 193 supplies a 2k bit number which has leftmost bits from register R2 (reference 
numeral 192) and rightmost bits from register Ri (reference numeral 191). During the second or 
Z-phase of prosecution, multiplexor 193 supplies a different 2k bits of data to adder 185. In 
particular, during the Z-phase multiplexor 1 93 supplies as its leftmost k bits the contents of 
register Ri, and as its rightmost k bits the contents of register Ro (reference numeral 190). 

In contrast to the full-width registers 10, 20, 40, and 50 in Figure 1, the corresponding 
registers in a partitioned system have fewer bits. In particular, the corresponding B and A'^ 
variable registers in a general processing element PE preferably employs a width equal to 2k bits. 
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However, for the rightmost processing element, a larger number of bits is desired. In particular, 
in the case in which n equals 512, registers 120 and 140 in Figure 4 preferably have a width of 96 
bits. Multiplexor 121 selects the contents of register B (reference numeral 120) during the 
X-phase of computation and likewise selects the contents of register (reference numeral 140) 
5 during the Z-phase of computation. In general, the overall n-h\t wide series of computations is 
broken down into partitions of any convenient size. It is not even necessary that all of the 
processor elements are the same size or process the same data width. However, for 
conveniences of circuit design and circuit layout, it is preferable that each of the individual 
processing elements (except for the rightmost element, PEo) have the same data processing 

10 capability in terms of data width. Therefore, in general, for purposes of consideration and 

discussion herein, it is assumed that there are a total ofd-^1 processing elements labeled from 
PEo through PEd. Processing element PEo preferably has a structure such as that shown in Figure 

t 4, PEd has the preferred structure illustrated in Figure 6, although it is noted that a more generic 

structure, such as that shown in Figure 5, may be employed for the leftmost processor element 

35 Pcd though it is not necessary that this leftmost processing element be any more complicated than 

J that shown in Figure 6. 

^ Also, for purposes of convenience of circuit design, layout, and packaging efficiency, it is 

T generally desirable that the data width, of each processing element be an integer multiple of k. 

^ In the designs presented herein for a value of « = 5 12, processor elements PEi through PEa-i, 

;20 each process data in 2k bit wide chunks. Thus, in this example, W = 2k, where W is the width of 
the data in each of the typical or generic forms of processing element, as illustrated in Figures 5 
and 5 A. It is noted that processor element PEo as shown in Figure 4 possesses an extra k bit 
processing capability, as is more particularly described below. Thus, if each typical processing 
element PEi processes data in ^bit wide chunks and if there are + 7 processing elements with 
25 the rightmost processing element processing an extra k bits, then it is the preferred case that n = 
Wd + k Thus, in general, the output of multiplexor 121 preferably comprises W + k bits. The 
leftmost third of these bits are supplied to multiplier 173, the middle third of the bits in register 
BN (reference numeral 198) are supplied to multiplier 172, and the rightmost third bits are 
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supplied to multiplier 171. Multipliers 171, 172, and 173 are thus each k bit by k bit multipliers. 
In this regard, it is noted that the original relatively large multiplier array 70 in Figure 1 employs 
an n by A: muhiplier. However, it is noted that the partitioning of the computation into a system 
employing a plurality of nearly identical processing elements results in the construction of 
circuits which now utilize multipliers which operate much more quickly since each multiplier 
now is typically only k bits by k bits. And clearly, since k is typically much less than n, 
processing takes place significantly faster. 

The leftmost of the 2k bits output from multiplier 173 are supplied as a partial product out 
(PPO) to the next unit in the chain. In particular, it should be appreciated that in the discussions 
herein, that the natural order of processing is from the rightmost on through to the leftmost 
processing element in the chain (see Figure 7). Thus, data is passed from one processing element 
to the processing element on its immediate left. However, it should be noted that left and right 
are relative terms usefiil essentially only for descriptive and understanding purposes. The 
rightmost k bits from multiplier 173 are supplied as the leftmost k bits of a 2k bit augend supplied 
to adder 175. The rightmost k bits of this 2k bit augend are supplied from the lower or rightmost 
k bits of multiplier 172. Thus, the rightmost k bits of multipliers 173 and 172, respectively, are 
combined, as shown m Figure 4, to supply a 2k bit wide augend to adder 175. Adder 175 also 
has as its other input a 2A:bit augend which is supplied from the leftmost A: bits of multiplier 172 
and 171, respectively, with multiplier 172 supplying the leftmost A: bits of the 2k bit augend and 
with multiplier 171 supplying the rightmost k bits of the 2k bit augend supplied to adder 175. 
Thus, adder 175 is a 2k bit wide adder. An equivalent but alternate connection arrangement is 
shown in Figure 4A. 

Multiplexor 1 52 operates to select, during the X-phase of computation, k bits from 
register Ro (reference numeral 190). During the Z-phase, multiplexor 152 selects as its input the 
contents of temporary register 150 containing the variable Xo. The output of multiplexor 152 is 
supplied to adder 165 which is k bits in width. Adder 165 receives two augends, namely, the 
rightmost k bits from multiplier 171 and the k bits supplied from multiplexor 152, The output of 
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adder 165 is stored in temporary register 150 and is also supplied to multiplier 180 which is also 
a k bit by k bit multiplier. The other factor supplied to multiplier 1 80 is the contents of register 
160 which contains the variable s, (The calculation of s as -1/No mod R is efficiently carried out 
in the circuit shown in Figure 17 which is discussed in detail below.) The output of multiplier 
1 80 is supplied to register 130 which thus contains the value y as defined by the algorithm set out 
above. 

The output of register 130 is supplied to multiplexor 131 and is also supplied to the next 
processing element PEi (see Figure 5). Multiplexor 131 operates to select a portion of the 
variable A which is one of the factors in the multiplication operation. (Other k bit wide portions 
of variable A are selected by their respective processing elements.) In particular, register 1 10 
contains the rightmost k bits of the variable A, Thus, during the X-phase of operation, 
multiplexor 131 operates to select the contents of register 1 10 to be supplied to multipliers 173, 
172, and 171, as shown. Likewise, during the Z-phase of computation, multiplexor 131 operates 
to select the variable from register 130 to be supplied to this same set of multipliers as the other 
factor. 

A carry-out signal line from adder 165 is also supplied as a carry input to the lowest order 
position in adder 185, as shown. Additionally, adder 175 supplies a first carry-out signal line to 
the next processing element in the chain; similarly, adder 185 also supplies a second carry-out 
signal line to the next processing element in the chain. In particular, since Figure 4 illustrates 
processing element PEo, carry-out signal line 1 and carry-out signal line 2 are both provided to 
processing element PEi. The connections between PEo and PEi are readily apparent simply by 
placing Figure 4 to the right of Figure 5. In particular, processing element PEo supplies the 
variable y, the partial product out, and the two carry-out signal lines to the inputs shown in PEi of 
Figure 5. In particular, it is also noted that the variable 7 (that is, the contents of register 130) is 
supplied to each one of the individual processing elements. And lastly, with respect to Figure 4, 
it is noted that the output of adder 185 is supplied to registers Ro and Ri shown at the top of 
Figure 4. As indicated above, it is the register set (containing Ri and Ro on the right) which 
ultimately contains the desired calculation result. Accordingly, reference numeral 1 00 in Figure 
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4 describing processing element PEo does not include this register set. This register set is 
discussed separately below in terms of some of the other variations and structures that are 
employed in the present invention. 

Attention is now directed to a discussion of Figure 5 which illustrates a more typical 
processor element and, in particular, which illustrates the form of a processor element which may 
be repeated in a circuit/system chain which is as long as is required to process factors which are n 
bits wide. 

With specific reference to Figure 5, it is noted that it is similar to Figure 4 except that the 
part of the processing dealing with k bit wide operations involving s and No need not be present 
in any processing elements except the rightmost one, namely, PEo. In particular, Figure 5 
indicates that the generic form of a processing element PEp bearing reference numeral 200 
specifically does include register BN (reference numeral 298) but does not include the other 
registers shown. One of the significant differences between Figures 4 and 5 is that register 220 
contains only a portion of the bits for the second factor B, In particular, register 220 contains 2k 
bit wide chunks designated as B2P+2 and 82^+/, where p ranges from 1 tod - L Again, as above, 
multiplexor 221 selects either the 2k bits from register 220 or the 2k bits fi^om register 240 which 
has corresponding portions (here 2k bits chunks) of the variable N, Accordingly, register BN is 
2k bits wide. Unlike register 198 in Figure 4, register 298 (BN) in Figure 5 is only 2k bits wide. 
In one preferred embodiment of the present invention when w = 512, register BN is 64 bits wide. 

From an overall perspective, general processing element PEi (reference numeral 200 as 
shown in Figure 5) accepts, as input from the right, the value of;^, the partial product in, carry-in 
1 and carry-in 2. Processor element PEi also has as an input the corresponding portion of the k 
bits of the multiplier factor A from register 210. The register involvement for registers, 292, 291, 
and 290 is substantially as shown in Figure 4 except now shown in the generic version of a 
processor element. It is these registers that store intermediate values between phases and 
ultimately store the completed product, AB mod N, Also, from an overall perspective, processor 
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element 200 produces, as an output, a k bit partial product out which is supplied to the processor 
element on its left together with carryout signals 1 and 2 which are supplied to the corresponding 
adders 275 and 285 in the processor element on the left. The output of adder 285 is supplied 
back to registers /?2p+y and R2p. Accordingly, other than the connections to the register sets for R, 
5 B, N, and A, the processing elements are connected simply by matching partial products in and 

out and carries in and out 1 and 2. Accordingly, in systems constructed in accordance with those 
aspects of the present invention which employ a plurality of similar processing units, the overall 
system is constructed by starting with the circuit shown in Figures 4 or 4A as a rightmost 
position and placing, in adjacent positions, processing elements similar to those shown in Figures 
10 5 or 5 A. The overall configuration, therefore, is seen in Figure 7. 



However, before proceeding, it is useful to consider the fact that the leftmost processor 
3 element PEd does not have to be as complicated as the processing elements to its right such as 

!f these shown in Figures 5 or 5 A. In particular, the leftmost processing element only needs to 

3 process k bits. In the Jf-phase of operation, the circuit shown in Figure 6 acts to add carry-in 1 to 

'15 the partial product input to the leftmost processing element via increment-carry circuit 375. 

Likewise, adder 385 adds carry-in 2 to the other input to adder 385 to produce an output which is 
^ supplied to register R2d in the immediate preceding processor element. In the Z-phase of 

I operation as controlled by AND-gate 399, the contents of register R2i (reference numeral 390) 

-A 

^ are added to the output of increment carry circuit 375 and this is also supplied to register R2i in 

20 the feedback configuration as shown. Accordingly, it is seen that in partitioned embodiments of 
the present invention, it is preferable to employ a leftmost processing element which is simpler 
than that which is generally required in one of the generic processing elements between the 
rightmost and leftmost elements. However, while preferable, this substitution is not mandatory. 



The partitioning of the computational problem as provided in one embodiment of the 
25 present invention into a solution having a plurality of nearly identical processing elements 
provides significant advantages in terms of design, efficiency, layout, and structure. 
Concomitantly, these advantages also lead to advantages in circuit speed and throughput. 
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However, it is also very important to note that the partitioning into a plurality of processing 
elements also provides significant advantages in terms of the fact that a pipelined operation is 
now possible. In particular, while pipelined operations generally introduce a small initial delay, 
the total throughput, as measured in terms of modulo N multiplications per time unit is 
significantly improved. Accordingly, a significant portion of the description below is devoted to 
a discussion of the use of the described partitioned processing element structure in conjunction 
with a pipelined method for operating the circuits shovm in Figures 4, 5, and 6, and variations 
thereof 

However, before embarking on a discussion regarding the pipelining aspects of the 
present invention, it is also useful to note that the circuits shown in Figures 4-7 are perfectly 
capable of operation in a non-pipelined fashion. Such a mode of operation is illustrated in Figure 
8. In particular, it is noted that Figure 8 is a logical time-sequence diagram illustrating the use of 
the register set Ro through R33 as a final and temporary storage medium for passing information 
between the X-phase of computation and the Z-phase of computation. Figure 8 also more 
particularly illustrates the distinction pointed out above between the register set and the 
individual processing elements. This figure also illustrates the unique positions for the rightmost 
and leftmost processing elements wherein the rightmost element is supplied with information 
from three registers and wherein the leftmost processing element receives direct information only 
from the leftmost portion of the register set, namely, R33 since, in this particular case, n is 
assumed to be 1,024 and k is assumed to be 32. Not shovm in Figure 8 are the signal connections 
between the processing elements. Rather, Figure 8 is meant to be illustrative of time sequencing 
and the utilization of the register set. In particular, it should also be noted that, in Figure 8, the 
processor elements in the upper half of the illustration are all operating in the X-phase at the 
same time, and likewise, all of the processing elements in the lower portion are operating in the 
Z-phase. Variations of this operational modality are more particularly described below with 
respect to Figure 9 and considerations relating to pipelining of the information into and out of the 
circuit. In the case of no pipelining, such as shovm in Figure 8, all of the processing elements 
start to process data at the same time and finish at the same time. In any given clock cycle, all of 
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the processing elements are either all in the Jf-phase or are all in the Z-phase of calculation. In 
this node, each processing element updates a fixed slice of the complete partial result register 
(two Ri registers). Since all of the partial product registers are updated at the same time, 
everything works smoothly in accordance with the algorithm described above. 

5 Attention is now directed to that aspect of the present invention in which the processing 

elements are operated in a pipelined fashion. In order to achieve this result, certain hardware 
modifications are made to the circuits shown in Figures 4 and 5. These modifications are more 
particularly illustrated in Figures 10 and 1 1, respectively, to be discussed more particularly 
below. 

1 0 However, for purposes of better understanding the utilization of the processing elements 

in a pipelined fashion, attention is specifically directed to Figure 9. In the pipelined approach, it 
[ is the case that, in a given clock cycle, any two adjacent processing elements are always in 

I different phases with the processing element processing the less significant slice of data always 

I being one clock cycle ahead. As seen by the circular arrows in Figure 9, it is unfortunately the 

J 5 case that, while a given processing element is in the Ji-phase, it requires, as input, a 32-bit value 
= from the Z-phase that is being calculated at the same time by the next processing element in the 

^ chain that is still in the previous Z-phase. For example, as shown in Figure 8, the rightmost 

^ processing element PEo on the top right is in the ^-phase. This requires, as an input, the value in 

^ R2 from processing element PEi which is one clock cycle behind in the Z-phase. This problem is 

320 solved by adding a feedback paths from the next processing element in the chain, which links to 
a k-hit adder (see reference numeral 235 in Figure 10 and reference numeral 135 in Figure 1 1). 
This solution creates additional delay due to the presence of a new ^-bit adder. However, the 
maximum working frequency is not significantly affected since a A:-bit adder is a relatively fast 
circuit. Additionally, it is noted that the previous signal path, before this change, was not a 
25 critical path. The original critical path occurred in the rightmost processing element PEo due to 
the calculation of the constant The advantage to this particular solution is that there is no need 
to modify the formulas in the algorithm; however, on the other hand, the maximum frequency is 
nonetheless slightly effected. Additional variations, to be considered more particularly below, 
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consider this minor problem and provide yet another solution which eliminates the delay 
introduced by adder 235 and 135. In any event, either of the two pipelining solutions presented is 
an improved solution over that provided by the purely parallel approach illustrated in Figure 8. 

As pointed out above, Figure 10 is similar to Figure 5, but more particularly illustrates the 
inclusion of extra hardware elements that are used to achieve smooth operation in a pipelined 
fashion. In particular, latches 232, 233, and 234 are added as temporary storage mechanisms 
between processors elements for holding the k bit wide partial products out (PPO), and the single 
bit carry-out lines 1 (from adder 275) and 2 (from adder 285). Additionally, it is noted that latch 
23 1 stores either the selected k bit wide portion of multiplier factor Ai or the constant >». This is 
provided in an alternating fashion from multiplexor 13 1 (as shovra in Figure 1 1). Additionally, it 
is noted that the lower k bits from the output of adder 285 are supplied to the adjacent adder 235 
which is actually present in the preceding processing element, namely the one to the right. In a 
similar fashion, the lower k bits from the next (that is, the left) processing element are supplied to 
adder 235. Additionally, there is a feedback connection (not shown for reasons of drawing 
congestion) from the output of adder 235 to the corresponding segment of the register "set," 
namely, to R2p+i. 

Similar changes in the circuit are made to the rightmost processing element PEo, as shown 
in Figure 1 1. In particular, latches 131, 132, 133, and 134 are added to serve a function that is 
the same as that provided by latches 231, 232, 233, and 234 in Figure 10. And as in Figure 10, 
adder 135 is now included to incorporate the extra addition step for pipelined operations. It is 
also noted that latch 131' in Figure 1 1 is supplied from multiplexor 131. It is from this latch that 
values of Ai andj^ are supplied to subsequent processing elements in the chain. In this regard, it 
is also noted that register 1 10 containing the value Ai is illustrated in Figure 11 as a A: bit register, 
while in fact the preferred embodiment is the one illustrated in Figure 1 in which a long A 
register with n + 1 bits provides information to a multiplexor which selects subsequent k bit wide 
chunks from the contents of the A register. Accordingly, register 1 10 in Figure 1 1 is preferably 
constructed as illustrated from register 10 and multiplexor 1 1 in Figure 1. The simplification 
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shown in Figure 1 1 is only for clarity and for ease of understanding. Also, as is seen in the 
corresponding portion of Figure 4, the output of multiplexor 121 is preferably W + k bits wide 
where Wis the width of the data chunks processed by each of the generic processing elements. 

Before proceeding to a discussion of yet another preferred embodiment of the present 
5 invention, it is worthwhile to consider the development described so far so in order to provide 
some overall perspective. In particular, a first preferred embodiment of the present invention 
provides a circuit such as that shown in Figure 1 which employs relatively large multiplier and 
adder arrays. In a second preferred embodiment, the adder and multiplier arrays are partitioned 
so as to be deployed in a chained sequence of individual processing elements with each one 
10 possessing the same structure and passing information from the rightmost to the leftmost 

processing elements in a system which efficiently carries out the same operations as shown in 
■ !: Figure 1 . In a third preferred embodiment of the present invention, the processing elements are 

' 4 further provided with an additional adder and latches which enable the processing elements to be 

n operated in a pipelined fashion, such as illustrated in Figure 9. In the next preferred embodiment 

I; ^5 of the present invention which is now considered in detail below, additional adders 135 and 235 
\fl are repositioned in the circuit so as not to negatively impact critical dataflow paths. It is now this 

U embodiment which is described. In particular, in this embodiment, the processing elements and 

\ : register sets are configured as shown in Figure 12. In particular, it is noted that, in Figure 12, the 

Q register connections to the individual processing elements are in fact different. This difference is 

i; j20 due to the repositioning of the adder. 

In particular. Figure 13 illustrates the repositioning of adder 135 from Figure 1 1 and 
likewise, Figure 14 illustrates the repositioning of adder 235 from Figure 10 to the position 
shown as adder 435' as shown in Figure 14. Accordingly, the design illustrated in Figures 10 and 
1 1 for pipelined operations is improved even further by moving the indicated adder to the input 
25 stage of the processing elements which is facilitated by eliminating certain feedback paths 
between the processing elements, as shown. The adder is moved from the output of the 
processing element to the partial product input (R register path) and works in parallel with the 
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slower multiplier function blocks. This eliminates an adder from a critical path. From Figure 9, 
it can be seen that when processor element PEp is in the A'-phase, it requires an input from both 
register portions R2p + 2 and R2p +1 . The R2p + 1 value is actually updated by the p'^ processor 
element during its previous clock cycle. The "problem" is that the value in R2P + 25 which is 
5 supposed to be contain the value of Z2p+ 2 is updated in the same clock cycle by processor 

element p + 1 (PEp + 1). It is noted that during the X-phase, processor element PEp adds the value 
Z2p + 2 contained in R2p+ 2 to the upper k bits of its output and loads the result into R2p+ 1 (this is the 
X2p + 1 value). Given that the contents of register R2p+ 1 are used and updated exclusively by PEp, 
one can proceed as follows: (1) during the A^-phase, processor element PEp does not add the 
10 value of R2P + 2 to its output before loading R2p + 1; and (2) during the Z-phase PEp receives as an 
extra input, the value in register R2p + 2 (which at this time has been updated by PEp+ 1 with Z2p + 2 
and adds this immediately to the R2p + 1 input before any further processing). The modifications 
to the circuit shovra in Figure 11, which are illustrated in the circuit of Figure 13, are designed to 
^ accomplish these goals. 

ri5 The consequence of step (1) recited in the previous paragraph is that at this point the 

^ - value generated by the processing elements during the X-phase is not any more the same as 

|:r3 described in the algorithm set forth above. In order to compensate for this difference, another 

Vl term is added during the Z-phase. The benefit of this change is an increase in the maximum 

frequency of operation and a reduction in the power of the needed by the circuit. Additionally, 
r$S) there are also advantages in terms of a reduced need for silicon area (that is, chip "real estate") 
together with advantages in having a more uniform and repeatable circuit design. Accordingly, 
Figure 12 illustrates the new flow of data between the R register "set" and the processing 
elements. Likewise, Figures 13 and 14 illustrate the presence of additional circuitry to 
accomplish the objectives stated above. 

25 The specific changes to the rightmost processing element for the improved pipelining 

version of the present invention are now specifically set forth. As above, a partial product out 
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from multiplier 173 is latched up into A:-bit wide register 432. Additionally, the variable M from 
multiplexor 131 is latched up into latch 437. 

Repositioned adder 435 is an adder having a width of 2k bits. It also receives a carry 
input signal (carry-in 3) and includes two input signal lines. A 2k bit wide signal comes from a 
5 combination of the output from AND-gate 402 which is supplied from register Ri (reference 

numeral 191). Register 191 also supplies multiplexor 193 which has as its other input the A: bit 
output signal from register Ro (reference numeral 190). The output of multiplexor 193 under the 
control of the Select" signal line which causes the supply of either the output of register Ri 
or register Ro as the rightmost k bits for the right input to adder 435. (Note though that adders 
10 and multipliers are symmetric with respect to the use of left and right inputs since the desired 

operations are commutative.) The first (rightmost) 2k bit input to adder 435 is either (Ri , Ro) or 
{000 ... 0, Ri) depending on the "X/Z Select" signal being 1 or 0 , respectively. The 
S Select" signal configures the circuits for Jf-phase or for Z-phase operation. During the X-phase, 

'f^ adder 435 executes the following operation: (00 . . . 0, Ri) + 0 which resuh is sent to adder 135. 

3 5 In comparison with Figure 1 1 , it is seen that adder circuit 1 85 in Figure 1 3 receives (Ri, Ro) but 
J can also receive the additional signal input (R2, 00 . . . 0). The reason for this option is based on 

' pipelining operations because in such a mode the Processing Element (PE) on the left is always 

^ behind one clock cycle. For example, since PEi in Figure 1 1 is responsible for updating the R2 

T register with the Z value, this means that during the X-phase PEo needs the Z value stored in R2 

^0 in PEi which is still generating it. Thus, in Figure 11, adder 135 is used to transform the X value 
3 in R2 to the successive Z value. However, in contrast in Figure 13, the value in R2 is added later 

in the next phase (a Z phase) via adder 435 which is not in a critical path. 

The signal "Select R2" is always 'zero' while the signal "X/Z Select" controls the X and 
Z phase during modular multiplication. This signal, when set to 'one' provides the capability of 
25 performing regular multiplication as opposed to modular multiplication as needed, or as desired. 
For regular multiplication, the "X/Z Select" signal line is always "zero" while the "Select R2" 
signal line is always "one." 
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The other input to adder 435 is a 2k bit wide signal whose rightmost k bits , driven by the 
AND-gate 401, are all zeros during a modular multiplication or equal to the Register R2 value 
during a standard multiplication as determined by the signal "Select R2". The output of AND- 
gate 401 is connected now to the lower k bits of the leftmost 2k bit input to adder 435. The 
5 leftmost k bits of this second input comes from register R2 (reference numeral 192) under the 
control of the "X/Z Select " signal line which controls AND-gate 403. AND-gate 403 is, like 
multiplexor 193, also under control of the "X/Z Select" signal line, as shown. The 
reconfiguration of the adder's input signals is necessitated by the repositioning of adder 135 to a 
position which is not in a time-critical path. 

10 The fiinctioning of signal line "Select PEo" is now more particularly described. The 

inclusion and fiinctioning of this control line is not related to the repositioning of adder 435. 
t When signal line "Select PEo" is "one" the hardware in the processing element becomes 

:j equivalent to the generic hardware processor element P/ (1 <i < d). When the "Select PEo" 

3 signal line is set to "one," multiplier 406 selects the "Previous P" input signal bus and provides it 

15 to adder 175 (which is equivalent to adder 275 in PE, ). The output of AND-gate 405 changes 

from "zero" (in the case of PEo fiinctioning) to the value driven by the carry input signal line for 
^ adder 175 (or 275 in PE/ fiinctioning). Multiplexor 404 selects the "Carry In 2" signal line and 

]; provides it as a carry input to adder 185 or 285 in PEi fimctioning). Accordingly, the "Select 

3 PEo" signal line is used to "disable" the following devices so that the processing element operates 

JO as a generic PE/ rather than as PEo : multiplier 171, adder 165, multiplexor 152, multiplier 180, 
register 150 and register 160. 

There are two cases in which it is desired that the "Select PEo" signal line should be 
driven into the "one" state. This means that the PE behaves specifically like a generic PE, as 
opposed to the rightmost PEo. 

25 The first case is when the system is designed comprising two separate chains of 

Processing Elements. For example, each of the two chains is made up of a concatenation of one 



POU920000124US1 



-34- 



PEo together with seven PE/s (that is, with eight Processing Elements per chain). These two 
chains (with eight PE's each) are particularly useful in carrying out operations of modular 
multiplication involving public key cryptography algorithms such as the RSA algorithm using the 
Chinese Remainder Theorem (CRT). In such cases, each of the two chains operates 
independently to perform two modular multiplications. In the case of modular multiplication as 
described above, there is thus provided a command which effectuates this operation together with 
an exponentiation function which is described in more detail below. In this case, the two chains 
of Processing Elements are concatenated to form a longer chain that is thus able to process more 
data in the same amount of time. In this case, the "PEo" on the rightmost position of the left 
chain behaves as a PE, and receives the inputs from PE7 (here "7" is used as an example which is 
in harmony with the exemplary chain size of eight, as recited above) from the right chain. This is 
accomplished by setting the "Select PEo" signal to "one." These two chains may be represented 
diagrammatically as follows: 

PEtb PE55 . . . PEy^PEofi < > PE7/1 PEtf^ . . . PE/>iPEoy4 

In the event that the hardware herein is not being operated in the Chinese Remainder Theorem 
mode (to be discussed in more detail below), VEqb acts as a PE/ and its "Select PEo" signal input 
line is set to "one." There is also one other input control signal that is set to "one" in order to 
have ?EoB act as a PE,. In particular, this signal line is labeled "Auxiliary Select" in Figure 13. 

More particularly, control line "Select PEo" controls the operation of multiplexors 404 
and 406 and AND-gate 405. In the PEo mode of operation, the carry-in 1 signal line is supplied 
to adder 175 together with the signal from the previous PE signal line coming in to the modified 
rightmost processing element shown in Figure 13. If it is not in "PEo mode," no carry input is 
supplied to adder 175. Likewise, based upon the state of the "Select PEo" signal line, multiplexor 
404 operates to select, as a carry input to the low order position of adder 175, either the usual 
carry-out signal from adder 165 or, in the event of non-PEo mode operation, the signal supplied 
to the carry input of adder 1 85 is the carry-in 2 signal. Apart from these variations, the rest of the 
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circuits shown in Figure 13 operate in substantially the same manner as their counterparts in 
Figure 1 1 . 

Figure 13 also introduces several other signal lines for proper operation in various 
hardware modes. As described above the "Auxiliary Select" signal line is a 2 bit signal taking on 
the values "00," "07," or "70." The "Auxiliary Select" line has the value "70" to PEob above to 
concatenate FEob with ?E7a on its right in the case of non-CRT operation. This is the only time 
that the "Auxiliary Select" signal bus is set to this value. In the other cases, this signal line is set 
to "07" during the Z-phase (Select A7Z = 7). The "00" value of "Auxiliary Select" selects the A/ 
input used for the Jf-phase while the "07" value for this signal line selects the 7 input for the 
Z-phase of operation. 

With respect to the other signal lines present in Figure 13, the "Select 7? or Ji" signal line 
is equivalent to "Select X/Z"; and the "Select R2" signal line is driven independently when the 
Processing Elements are used to perform standard multiplication operations as opposed to 
modular multiplication. The "Select B or JST' signal line assumes the value given by "Select Jt7Z" 
during the next clock cycle (that is, the anticipated version of "Select A7Z'). The reason for this 
is that the output of multiplexor 121 is used to select what is stored in BN register 198 which 
contains B during an X-phase and n during a Z-phase. 

Figure 14 illustrates modifications made to the circuit shown in Figure 10 to 
accommodate repositioning adder 235 in Figure 10 to a position in the signal flow path which 
reduces time criticality with respect to addition operations. With respect to the specific 
differences between Figures 10 and 14, it is noted that, in Figure 14, it is no longer necessary to 
supply the low order k bit output from adder 285 to the processing element to the right. 
Additionally, it is noted that instead of the signal line being labeled Ai / y, the input signal line is 
labeled M to reflect the fact that multiplexor 131 in Figure 13 now has three possible inputs to 
select from rather than just Ai or^'. The third input of multiplexor 131 (that is, the "Previous M" 
signal line) is used to concatenate ?Eob to FEja (as per the example given above) during 
non-CRT operations. This allows on-the-fly construction of a long chain of Processing Elements 
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(sixteen in the example) versus two independent chains of half as many (that is, eight in the 
example) Processing Elements. 

Additionally, adder 435' which is 2k bits wide is now interposed between its 
corresponding register set segment and adder 285. In particular, the output of adder 435' is 
5 supplied as the second input to adder 285 and the carry out of adder 435' is supplied to latch C3 
(reference numeral 436) which supplies the carry-out 3 signal line. The contents of register R2p+ 
2 (reference numeral 292') which is k bits in width is supplied as the lower ^-bit portion of the 
left adder input under control of AND-gate array 401 which is in turn controlled by the signal 
line "Select R2P + 2." The contents of register R2P + 2 are also supplied as the upper A:-bit portion of 
10 the left adder input under control of AND-gate array 403 which is in turn controlled by the "X/Z 
3 Select" signal line. The right input to adder 435' is also 2k bits in width and is supplied from 

J AND-gate array 402 and from multiplexor 493. Under control of the "X/Z Select" signal line, 

^ multiplexor 493 provides either the contents of register R2p+ 1 (reference numeral 291') or the 

U contents of register R2p from the processing element on the right. The 2A:-bit data portion 

nl5 supplied to the left input of adder 435' is controlled by AND-gate 401 and by AND-gate 403 . 
^ The right 2A:-bit input to adder 435' includes two portions one of which is a high order k bit wide 

Z_ portion which is either zero or the ^-bit data portion coming from register R2P+2 (reference 

3 numeral 292' ) control of AND-gate array 401 which is also under control of the "Select R2 " 

3 signal line. The lower order k bit wide portion of the right input to adder 435' is selected by 

20 multiplexor 493 to be either the contents of register 291' (that is, R2p+ 1) or the contents of the 
292' register (that is, R2p) in the processing element to the right. The operation of the circuits 
described produces the result that adder 285 (Figure 14) accumulates the results of the 
multiplication operations performed by multipliers 272 and 273 together with the output of adder 
275. The left input of adder 285 is dependent on the phase of the operation for the Processor 
25 Element containing adder 285. For example, during theX-phase, the result is {00 , . .0, R2i+i) 

while during the Z-phase, the result is the binary sum (R2i+i, R2i) + (R2i+2, 00 . . , 0\ where "00 . . . 
0" is k bits wide. The term including R2i+i is added only during the Z-phase since, during the 
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X-phase, this register value is still being updated by the Processing Element to the left. This 
aspect is best seen in Figure 12. 

Additionally, it is noted that if one desires to employ a simplified leftmost processing 
element such as one that is similar to that shown in Figure 6, modifications are made to this 
5 circuit to accommodate the improved pipelining version associated with Figures 13 and 14. In 
particular, this is accomplished by the inclusion of an increment-carry circuit 439 between 
previously employed AND-gate array 399 and k bit wide adder 385. The other signals supplied 
to increment carry circuit 439 is a carry input dn which comes from latch 436 in the processing 
element to the immediate right of the circuit shown in Figure 15. In particular, this signal line is 
10 designated as carry-out 3 in Figure 14. As above, the use of a simplified leftmost processing 
element (PEd) is optional but is clearly desired for purposes of circuit simplification, speed, and 
cost. The Processing Element PEend or PEd includes the ftinction of adding the previous PPO 
'■4 (Partial Product Out) from the PE to its right to the potential carry out signal from adder 435' 
n which signal is temporarily stored in latch C3 (436). This resuh is stored in register R2P . During 
J ¥5 the Z-phase, the result of this operation is accumulated in register R2P , as shown. 

m 

Is. It is noted that it is also possible to utilize the pipelined version of the present invention 

; ^ to process operands that are actually in fact wider than the hardware present in the processing 
U element chain width (n » Wd or equivalently n » mk) . The method for canydng out this extra 

Q wide operation processing is illustrated in Figure 16. In particular, each horizontal line in Figure 

20 16 represents a single clock cycle and each vertical column represents a slice of the data that is to 
be processed. Assuming that each processing element processes 64 bits of data {2k bits 
typically), the first column indicates that the lower two k bits of the data are always processed by 
processing element PEo. During the first clock cycle, only processing element PEo is active. All 
of the other processing elements are activated sequentially, clock cycle after clock cycle. This 
25 provides sufficient time to the previous processor element to generate the pipelined data for the 
next processing element. In fact, it is possible that the width of the operand is larger than the 
processing element chain itself For example, in the discussions herein, the situation in which 
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n= 512 bits has been considered. However, in accordance with this aspect of the present 
invention, it is possible to process operands that are longer than 512 bits using a pipelined 
hardware structure which is designed for 512 bits. In such circumstances the clock cycle after the 
first processing element is activated, the entire processing element chain is shifted left by 2k bits 
(see Figure 16) leaving the lower two k bits unprocessed. This shifting continues until the upper 
processing element (in this case, PEg) is capable of processing the upper 2k bits of the operand. 
Following this, the processing element chain, instead of shifting back to the home position, stays 
in place with the exception of the rightmost processing element PEo. The lower processing 
element, after the others go into a home position, continues processing the lower two ^-bit slice 
of the operand. When all of the processor elements are back in their home positions, the entire 
chain starts a shift left as before. This mechanism allows all of the processing elements to be 
busy all of the time and, accordingly, achieves a maximum performance level. Additionally, a 
new operation can start before the previous operation is finished. The approach described herein 
provides maximal performance in the sense that all of the Processing Elements are always busy. 
Additionally, the next operation can be started immediately without any delay and without idling 
any of the Processor Elements. Furthermore, these operations are fiiUy compatible with the 
pipelined approach as described above. 

As indicated very early above in the description for the present algorithm for computing 
AB mod it is desirable to begin the calculation with a value s which is equal to the negative 
inverse of the value No where the inverse is now taken modulo R where R = 2*. That is to say, in 
the initial presentation of the algorithm employed herein, the availability of the value s = -1/No 
mod R was assumed. A circuit for carrying out this calculation is illustrated in Figure 17 which 
shows, in its upper portion, a circuit for calculating successive values of the variable Q and 
correspondingly illustrates a circuit in its lower portion for calculating a companion variable S 
which ultimately becomes the desired s ~ -IINq mod 2^. In this regard, it is noted that the circuit 
shown in Figure 1 7 actually performs two operations. Firstly, it computes a multiplicative 
inverse modulo, a number which is a power of 2, and also at the same time computes the additive 
inverse of the multiplicative inverse. In ordinary, non-modular arithmetic, the computation of an 
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additive inverse is a relatively simple operation requiring either the addition or change of a single 
bit at the leftmost portion of a representative number or at most the addition of a 1 to the lov^ 
order position depending upon the format in which the numbers are stored. However, in the case 
of modular addition^ it is noted that the operation cannot be carried out as simply as it is for 
ordinary, non-modular arithmetic. Accordingly, it is noted that the circuit shovm in Figure 17 
actually carries out simultaneously two nontrivial operations modulo R. In particular, it 
computes a muhiplicative inverse while at the same time ensures that the final result is the 
negative additive inverse modulo R = 2^. 

In the context of the present invention, the algorithm set forth above for computing AB 
mod N employs the variable s = -1/No modulo R. However, the circuit shown in Figure 17 is 
capable of generating the negative multiplicative inverse of any ^-bit number A initially stored in 
the No register (reference numeral 501). The method employed for carrying out the formation of 
the desired negative multiplicative inverse is set forth below. The inputs to the process are the 
values k and the number whose negative multiplicative is desired, namely, A which is 
expressible as an ordered A:-tuple of the form {Uk-h . . * > cih ^o). The desired output of this 
process is a variable s = -1/A modulo 2*. In the process described below, the variable s is 
initially set equal to the value 2^ - L The variable A is also initially loaded into the Q register 
(reference numeral 504) at the start of the process. Accordingly, if the "Start" signal line is "7," 
then multiplexor 505 selects as its output the contents of register 501 which contain the value No 
or, more generally, a variable A whose negative multiple inverse is to be generated. Multiplexor 
505 also receives as an input the output of k bit adder 503. This adder has two inputs, namely, 
the leftmost k - 1 bits from Q register 504 and a k bit input the value of A as stored in register 
501 . Adder 503 also effectively performs a shift right operation under circumstances to be 
described more particularly below, and accordingly, a zero high-order bit is added as appropriate 
to effect this shift operation with zeros being shifted into the high-order position. 

The process for carrying out the desired calculation resulting in the variable S being 
transformed to -1/A mod 2* is set forth below: 
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# • 

Set5 = 2'-; 

For i = 1 to (k-l)do: 
Right shift Q one bit 
5 If rightmost bit of Q, namely Qi = 1, then 

5 = 5-2'; 

end if; 
End for. 

JO Accordingly, it is seen that the process in this embodiment of the present invention occurs 

3 in A: - i steps. At the last step, the contents of the S register are equal to the desired negative 

z multiplicative inverse of A (or No for the specific purposes of the present invention). It is also 

seen that the process for calculating the negative multiplicative inverse employs the concomitant 
f calculation and updating of two variables, S and Q. The upper portion of Figure 17 illustrates the 

15 updating and calculation of the variable Q, In particular, it is noted that if the rightmost bit of Q 
T (that is, Qi) is 7 then, via the utilization of AND-gate array 502, the contents of register 501 are 

5* added to the current value of Q from Q register 504 with the output being stored back in the Q 

J register via multiplexor 505. It is noted that, at this stage of operation, the "Start" signal line is 

^ not equal to "i" and, accordingly, multiplexor 505 selects as its input the output of adder 503. 

20 Otherwise, the initialization Q = A is carried out. 

The circuit in the lower portion of Figure 17 calculates the companion variable S which 
is also the desired output at the end of the process. It is noted that in the updating of the variable 
5, in accordance with the process indicated above, one performs a subtraction from the current 
value of S by an amount which is equal to a power of 2 (5 = 5 - 2' ). To effect the desired 
25 process, S register 560 is initially loaded with a value which is "all ones" representing the integer 
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2* - L AND-gate array 561 controls the writing of particular bits into the S register. In 
particular as seen in Figure 17, a A: bit wide vector from AND-gate array 561 is available for 
writing into register 560. AND-gate array 561 permits, during each clock cycle if necessary, the 
writing of a A: bit vector into S register 560. The selection of which vector is controlled by the 
5 current value in counter 563 which counts upwards from Otok- 1, and then immediately back to 
zero again in a rollover fashion. In the examples of the present invention described above, k is 
typically equal to 32 bits. As such, counter 563 need contain only 5 bits. In general, counter 563 
contains log2 L Thus, decoder ring 562 receives 5 bits and produces as an output a k 
bit vector, only one of whose entries is 1 . This is the essential operational feature of a decoder 

10 circuit. Counter 563 also supplies a signal line "ZeroCount" which is a "i" when the counter is 
all zeros. This signal line is also supplied to AND-gate array 561 which triggers a write-enable 

^ bit when Q(l) is "7" and the ZeroCount signal line is false and the Start signal line is false. 

J Accordingly, under these circumstances, AND-gate array 561, in accordance with the algorithm 

described above, then permits the writing of a 0 bit into the corresponding portion of S register 

45 560 as determined by the current value in register 563 which, in effect, contains the variable / 

-I recited in the algorithm listed above for negative multiplicative inverse calculation. It is in this 

fashion that the value of S is updated toS = S- 2\ Finally, at the end of the calculation, the 

;s value in the S register, which is initially set equal to all ones, is now equal to the negative 

^ multiplicative inverse modulo R of the value that was stored in the iVo register 501 . 

$0 

If instead of (-1/A) mod N, one wishes to calculate (1/A) mod N, one can employ the 
following algorithm: 
Set5 = 7 
Sete=^ 
25 For/ = 7/0 ('A:- 7; do: 

Right shift Q one bit 

If rightmost bit of namely Qi = 7, then 
S = S +2 (that is, set bit i to 1); 
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Q = Q^A 
end if; 
End for. 



Accordingly, there is provided a circuit and a process for producing in a single set of 
operations not only the multiplicative inverse modulo i? of a given number, but also, its 
arithmetic negative value modulo the same value i?. For purposes of the multiplication algorithm 
of AB mod described above, it is noted that it is the circuits shovra in Figure 17 which are 
preferably employed for the calculation of the variable s = -1/No mod R which is stored in 
registers 60 in Figure 1, 160 in Figures 4 and 4 A, 160 in Figure 11, and 160 in Figure 13. 

As discussed above, a primary purpose of the present invention is the multiplication of 
large integers modulo for cryptographic purposes. Since cryptography often involves the 
exponentiation operation, the use of the present hardware to perform exponentiation is now 
described. 

The relevant circuits and materials described above can be considered as implementing a 
specific function,/ with the following properties: 

MB) =^AB2-'"' modN; 

f(A 2^"^ B 2"^) =AB 2"'^ modN; 

/(Al"'^ 1) = A modN; 

if A < 2^ and 5 < 2^ then/(:4, B) < 2N; and 

if ^ < 2^ and .4 9^ A^, then/(:4, 7; < A^. 

In the above, the problem has been partitioned into m "words" of k bits each where mk^n + 2 
where n is the number of bits in the binary representation of A^. And as above. No is the least 
significant k bits of A^. And A'^ is, of course, odd. 
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In the discussion above, it was pointed out that multiplication modulo would normally 
be carried out in a two step process: 

Step 1: Results =M B) = A B 2 '"* modN 
Step 2: Result2 = /(Results 2^''^) =AB modN. 

From the above properties of f, it is seen that premultiplication of either ^ or 5 by 2""^ produces 
the same result in one step: 

Result =f(A 2"'\ B) ^f(A, B2'"^)=AB modN. 

This is clearly the preferred approach for performing modular multiplication in one shot situation 
since premultiplication by 2'"* is easily performed via a shift operation. However, in the case of 
exponentiation, one uses the modular multiplication fixnction, as implemented in the hardware 
described above, in a repeated fashion. In the present case then, exponentiation is carried out in a 
repeated fashion, but now one must deal with the fact hat there is a factor of 2"'"* present in the 
output of each iteration of the fimction, f; that is to say,/(14, B) =A B 2''''^ mod N, Accordingly, 
in the present invention, the hardware implemented function f is used but with the factor 2^"^ 
being "preapplied" to both of the multiplicands, A and B, as follows: /(^^ 2"^ B 2""') =AB 2^"' 
mod N. This way, since the function f introduces a factor of 2 ^"^ at each step, repeated iterations 
using preapplication of the 2'"* factor to both operands keeps a constant factor of 2'"^ as part of 
the result. As a last step this factor is removed using the function f as implemented by the 
present hardware in the following maimer: f(A 2^"*, 1) = A mod K Therefore, at the last iteration 
in an exponentiation operation, A is the output from previous repeated applications of the 
function / 

In order to see that this value of A going into the f function hardware at this stage is 
constructed as an appropriate exponential, consider the general case of constructing the value A^ 
mod A'^ where £ is an integer and in particular is an integer represented by the f + 7 bit binary 
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value et2 + e,.; -\- 62 2^ ei2 eo = I e/ 2', where is either "7" or "0." Here, 
advantage is taken of the fact that a sum in an exponent becomes a product (<f^^^cf<f)so that: 

Based upon this expression for in terms of the binary integer E, it is seen that the following 
algorithm provides a method for using the hardware for the function f herein to produce the result 

mod N, a result which is very important for cryptographic operations and particularly 
important for public key cryptographic systems. Here, A^, K, M, No and s{'^- 1 /Nq mod R 
where 7? = 2^ ) are as given above. The inputs to the method are the values A and E with E being 
a r + i bit binary integer. The method is summarized in the following outline: 

SetC = 2'"^ modN 

Zo =f(A, C) 

Z^Zo 

For i^liot 

z=mz) 

If et-i = 7, then Z = f(Z, Zo ), else continue 
End For 
Z =f(l Z) 

Thus, at the end of this method the value stored in the Z register is A^ mod N, as desired. This 
procedure is also summarized in the flow chart shown as Figure 18. 

A slightly different form of the exponentiation algorithm is implemented in Figure 19. It 
is also described in the pseudo code provided below: 

SetC = 2'^* modN 
Zo =f(A, C) 

If eo = 0, then set Z = 7, else set Z^Zo ^ 
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For i = 1 to t 

Zo ^f(Zo,, Zo) 

If 1, then Z = f(Z, Zo), else continue 
End For 
Z=f(lZ) 

In constructing circuits for implementing either of these methods for modular exponentiation, it 
should be noted that f is a symmetric function so that f(A, B) =f(B, A). If /is instead viewed as 
an operator, this condition is referred to as commutivity. Thus, circuits implementing/ can have 
their inputs switched with no change in operation. One also notes in the algorithm set forth 
immediately above that eo is the lowest order bit in the binary representation for the exponent E . 
As such, for the cryptographic purposes described herein, one notes that N is an odd number. 
Thus, it's lowest order bit position is always 1. Thus, for cryptographic purposes the step which 
tests to see if = 0 can be eliminated. 

As an example, a circuit which can implement either one of the algorithms for 
exponentiation is shown in Figure 20. The core of this exponentiation circuit is provided by an 
engine which implements the f(A, B) =AB 2^"^ mod N function. Thus, engine 600 may be 
implemented by means of any of the hardware components described above which performs this 
function. The output from multiplication modulo N engine 600 is provided to decoder 603 which 
operates under control of finite state machine (FSM) 607 to store this output either in Z register 
604 or in Zo register 605, or in both (to provide the Z = ZoStep in the algorithm of Figure 18), as 
needed. Thus, decoder 603 does not always function in accordance within the standard 
operational definition of a "decoder" which would normally have only one set of output lines 
carrying information. If the circuit of Figure 20 is intended to implement either of the 
exponentiation algorithms herein, then the outputs of registers 604 and 605 (Z and Zo) are both 
provided as inputs to multiplexors 601 (for input A) and 602 (for input B), These multiplexors 
are also provided with constants 1 and C = 2^^'"* mod N, It is noted, however, that the constant 
"7" could also have been provided instead as an input to multiplexor 601 . However, the constant 
C and the input A (which is used for computing A^'modN) need to be provided to different ones 
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of multiplexors 601 and 602 for the purpose of calculating the value Zo Q. Multiplexors 
601 and 602 and decoder 603 all operate under control of controller 607 which is preferably 
implemented as a Finite State Machine which can have as few as 6 states which depend only on 
the contents of index counter 608 (which counts from 0 to f and then resets back to 0) and on the 
selected bit from register 606 which contains the exponent E in binary form. 

For example, in implementing the algorithm illustrated in Figure 18, when counter 608 is 
at 0, controller 607 selects the A input for multiplexor 601 and the C input for multiplexor 602. 
It is also noted that, for both algorithms, the initialization and repetition aspects both involve two 
steps. Accordingly, FSM 607 also includes one-bit register 609 (step state register) which is 
indicative of this step state. Having used multiplexors 601 and 602 to select v4 and C as inputs to 
engine 600, FSM 607 also controls decoder (or router, if you will) 603 to store the output f(A, C) 
^AC 2'""^ mod N into Zo register 605. The design of FSM's for such purposes is standard and is 
well known and is, for example, described in the text "Digital Logic and Computer Design" by 
M. Morris Mano, Copyright 1979 by Prentice-Hall. 

In the use of the CRT as described above it is seen that one requires the constant C 
defined as 2^^"'^ mod A^. While the constant 2^"'^ is generally easy to determine and construct, the 
inclusion of the need for this to be modulo is a complicating factor. Note here too that it is the 
case that mk^n + 2 where n is the number of bits in A'^ and that m is picked to be the smallest 
integer satisfying this relationship. Thus 2^^""^ is always going to be greater than N and hence the 
modulo A'^ form is needed. However, this constant is readily calculable using the / engine 
described above. One first calculates T = 2^^^^' for a small value of t. The / engine is then used 
repeatedly as follows: 

XT, T) = 2^"* " ' 2"' " ' 2-"'' mod 

= 2"^*^^' modN 
y^2-^ - 2"^ " ^0 = 2"* " " mod N, 
j^2mk ^ 4t^ 2'"* ^ ^') = 2'"^ " mod etc. 
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This process is repeated until the first time that the result is greater than N. 

In public key cryptographic systems someone who wants to receive information picks two 
(large) prime numbers Np and Ng and publishes only their product N = Np Ng, The potential 
receiver then generates (or otherwise creates, often randomly) a public key E which is also 
5 published, Before publication, however, the receiver-to-be checks to make sure that E is 

relatively prime with the respect to the product (Np - 1) {Ng - 1), This is easily done since the 
receiver knows both Np and Ng. With and E thus knovm to the pubUc, anyone wishing to 
transmit a message A destined for the receiver can form the encrypted version c of the message 
by computing c = mod A^. Thus, encryption is an exponentiation operation modulo N. It is 
10 the "modulo A^' aspect which makes this a nonstandard arithmetic problem. However, the 
systems provided herein are particularly capable of performing the A^ mod operation. 

At the receiving end the message is decrypted as ^ = mod A^, where, as above, c is the 
n received/encrypted message and where Z) is a private key known only to the receiver and which 

J is calculated asD = E'^ mod [{Np - l){Ng- 7)]. This is something which can be computed by 

i 5 the receiver since the receiver (and only the receiver) knows the values A^^ and Np. (Since N = Np 
Ng is a large number, typically with thousands of bits, even though A^ be known, its factors, the 
\1 prime numbers A^^ and Np are very hard to determine. This fact lies at the heart of public key 

cryptography.) The receiver also computes, actually precomputes, several other values that are 
Q useful in efficient decryption. In particular, the receiver computes two values t/. Dp and Dg as 

20 follows: 

U ^ (1/Ng) mod Np, 
Dp = D mod (Np- 1\ 
Dg = D mod (Ng- 7). 

These values render it possible to more efficiently construct the desired result which is mod 
25 N, This process is more particularly illustrated in Figure 21 . (Coded message c is not to be 
confused with the constant C = 2^^"''' used above.) 
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Advantage is now taken of the fact that the receiver, knowing Np and Nq is able to 
calculate U, Dp and Dq so that advantage maybe taken of the Chinese Remainder Theorem. The 
coded message c is an integer between 0 and N = NpN^ where gcd (A^^, A^^) = 1 end where "gcd" 
stands for "greatest common denominator." If Cp= c mod Np and Cq = c mod Nq then the CRT 
implies that c may be computed as follows: 

c^Cq^{Nci{ {Cp- Cg) mod Np) U) mod Np, 
where U is as defined above. This result is now more particularly applied to the computation of 
cP mod A^, one first considers (c^)p which is defined as cP mod Np, Likewise, one also considers 
{(P)q which is similarly defined as (P mod A^^. Note that (c mod Np)^ mod Np= (c mod A^p)^^ 
where Dp = D mod (Np - 1/ Similarly, (c mod N^)^ mod Nq^ (cmodNg)^^ where, similarly Dg 
= D mod fNq - Ij. Thus, given c, Dp, Dq, Np, Nq and U the exponential cP mod A'^ can be 
calculated in three steps: 

Step 1. Cp = c mod Np;Cq = c mod A'^. 

Step 2. (Cp)d = {cp)^' mod A^^ ; {Cq)D = icq)^' mod A^^. 

Step 3. (P mod A^= {Cq)D + [ A^J( (Cp)o - (c^)d ) mod Np) U ] mod Np. 

Step 2 above is readily carried out using the methods set forth in Figures 1 8 and 19. Step 3 is a 
straightforward calculation not involving exponentiation. Furthermore, as indicated above it is 
possible to split the sequence of Processing Elements into two chains which together calculate 
{Cp)d and (c^)d simultaneously. ' 

Attention is now directed to a method for further simplifying the computation shown in 
step 1 immediately above. Since the input to the process is a relatively large number, perhaps 
being represented by as many as 2,048 bits, the calculation can be time consuming. However, 
the modular reduction is based on numbers Np and A^^ which are often roughly only half that size. 
Suppose then that, phrased more generally, one wishes to compute Ap=A mod Np and likewise Aq 
= A mod A'^. Without loss in generality one may assume that Np > Nq. Suppose further that rip 
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and rig are the number of bits in the binary representations for Np and iV^, respectively. Suppose 
even further that one picks values ntp and rrig such that these are the smallest integers for which : 



where k is the word size in the circuits described above for modular multiplication. With these 
parameters one may now write A in either of the two forms: 



depending on whether one wishes to compute either Ap or Ag, both of which are employable in 
the application of the CRT as described above. If A is of the order of 2,048 bits, then: rip + rig < 
2048; and in general: O^Aop< 2^"^^; 0<: Aog<: 2'"^'^ 0 <Aip< Np ; and 0 <:Ajg < Np, One further 
defines two constants Q = 2'^^'"^*mod Np and Q = 2"^^'"^*mod A^^. These constants have 
substantially the same role as the constant C = 2^^^"* mod N discussed above, but now these new 
constants are employed to facilitate computation on a smaller scale problem in accordance with 
the representation of A as having two parts (Aip and Aop for the mod Np calculation and Ajg and 
Aoq for the mod A^^ computation.) 

As indicated above the present inventors have provided circuits for construction of an 
engine which implements the function f(A, B) =AB 2"^"^ mod A^. This engine/circuit is also fully 
capable of implementing different fimctions in dependence on the m and A'' parameters. 
Accordingly, the functions fp and fg are defined as follows: 



nip rip +2, and 
mqk'^ng + 2^ 



A^Ajpl^p^+A 



or 



A=Aj,2^^^+A^ 



Oq y 



fp(A, B)=AB2-'"p^ mod A/, 



and 



fg(A, B) = AB2-^<^^ mod A/,. 
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Consider first the use of fp in the calculation of Ap based on the use of the two part representation 
oiAz& A,pT"p^ "^Aop. 

a = fp{Aop, J) = Aop 2-'"p'' mod Np 
b=fp(A,p2'"p'',l)= AipmodNp 
g = a + b = Aip+ Aop l-""* mod Np 
fp(g, Cp) = g 2-'""* 2+2'»P* mod Np , 

= g2'"p* modA'p, 

= Alp 2'"''*+^opmodNp 

= A mod Np 

-A, 

In the same manner one uses the circuits herein to compute Ag using the parameters nig and Ng to 
produce fg as defined above. 

The overall structure for a preferred embodiment of cryptographic engine 700 employing 
the circuit and operational principles set forth above is shown in Figure 22. The main feature of 
cryptographic engine 700 is the inclusion of modulo multiplier 600 as described above. It is 
noted that, as implemented herein as a sequence of independent Processing Elements (PE's), 
multiplier engine 600 is dividable into two pieces by the operation of electrically controlling a 
Processing Element so as to cause it to operate as a "PEo" element. This is particularly useful 
during decryption operations since in this circumstance the receiver knows both Np and A^^, 
whereas during encryption the sender knows only the product = A^^ A^^. 

For the calculation of mod A^, register set 658 contains registers for holding the 
following values: A, Bp, Bg, Np, Ng and U, where Bp = B mod (Np - 1) and Bg = B mod (A^^ - 7), 
Register set 658 also preferably includes at least two utility registers for holding temporary 
and/or intermediate results. In particular two such utility registers are preferably employed to 
contain the values A ig and Aog as described above, with Aop and A ip being thus stored in the AH 
and AL registers respectively. Clearly, the roles of these two utility registers are 
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interchangeable. Register set 658 also includes an output register which contains output results 
from multiplier engine 600. 

Cryptographic engine 700 also includes modular reduction unit 653 (also described herein 
as Auxiliary Computation circuit in Figure 23) which performs addition and subtraction 
operations and performs single shot modular reductions. 

The flow of signals across databus 670 between register set 658 to and from multiplier 
engine 600 and modular reduction unit 653 is carried out under control of Finite State Machine 
(FSM) Command Control Unit 660 in accordance with the methods, algorithms, and protocols 
set forth above for carrying out any or all of the following: modular multiplication, constant C 
generation, exponentiation and the use of the Chinese Remainder Theorem (CRT) for calculating 
modular numbers and for efficient exponentiation. 

I/O control unit 665, besides implementing the decoding and control function necessary 
to supply values such as A, B, N, Bp, B^, Np, and U to the registers set 658 through databus 
670, provides two important functions in the case of modular exponentiation with CRT: The 
first important function is that it dynamically calculates the value of m or rrip and and it also 
calculates the lengths of the exponents B or Bp and Bg, Each value of the m's is a function of the 
length of a modulus (position of the leading 1) and is a key parameter used throughout the 
operations. The length of an exponent is simply used to determine when to stop the 
exponentiation process. The traditional solution is the use of a length detector that monitor the 
value of each bit in this large registers. This approach has disadvantages in terms of requiring 
more silicon area and also in terms of electrical loading on the output of the registers. The 
approach used in the I/O control logic is much less wasteful and is based on the detection of the 
leading in the k bit word being written and the associated address. Every time a non-zero k 
bit word is written, a small piece of logic is used to calculate the location of the most significant 
' 1 ' which is being written, based on the address of the word itself, and is compared with a value 
stored in a register that is the result of the loading of the previous k bit word. If the new value 
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calculated is larger than the value stored in the register, the register is updated accordingly. The 
calculation of the m parameter follows a similar approach and thus saves the need for a lookup 
table and another large leading *r detector. The second important function is that in preparation 
for performing modular exponentiation with the CRT, the values of A ip, Aopy Aig, and Aoq, as 
5 described previously, are calculated and loaded into separate registers under control of I/O 
control unit 665. 

Commands which externally govern the operation of engine 700 are also supplied via I/O 
control unit 665. Attention is now directed to a checking system and method which takes the 
fullest advantage of the modular multiplication circuits described above. In general, there are 
10 several ways to provide checking for the results of the hardware operations carried out by the 
system of the present invention. However, most of the standard approaches to checking are 
negatively impacted by size, economies of chip real estate and/or by the fact that the arithmetic 
' J operations carried out are modulo N operations. For example, result checking based on a straight 

forward duplication of hardware is very expensive in terms of "silicon real estate." Error 
checking for the various function blocks employed (multipliers, adders, controls, etc.) is also 
C- very expensive and complicated. Lastly, the use of residue arithmetic check sum methods is not 

directly applicable to checksums for the modular multiplication hardware that implements the Z 
: =f{A,B) = AB 2'""^ mod N function described above. For example, if Z\ A ', and 5' are the check 
Q sums of Z, ^, and B, respectively, then it is still unfortunately the case that Z' is not necessarily 

i;^0 equal toJ{A 5'). Accordingly, driven by the inappropriateness of standard approaches to 

hardware operation checking, there is provided herein a method and system which is closely tied 
to the architecture described above and which is particularly tied to the fact that the systems 
herein perform modulo multiplication using X and Z phases of operation and employ a 
plurality of Processing Elements based on the notion of partitioning the operands involved into a 
25 plurality, m, of k bit words. 

For an easier understanding of the checking method and system herein, one starts with an 
understanding of the process described above: 
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Process inp uts: A,B,N (where N is, of course, odd) 

n = number of bits in the binary representation of A'^ 

k = number of bits in a word (i.e., in each chunk processed by one of the Processing 

Elements. 
m = smallest integer for which 
No = least significant k bits of N 

R = 2' 

s = (-l/No) modR 
/■=o 



Process output : Z = J{A, B) = AB 2 '"^ mod 
Process : 

Set Zo = 0 
For / = 0 to m~I do: 
X- phase : 

X, = Zi-^AiB 

Yi+i = s Xi,o mod R (where = least significant k bits of X,) 



Z- phase : 

Z,.y = (^-+r,.yAO/ R 

End for. 



Based on the above algorithm, structure, and process, the following equations lie at the 
heart of the model employed herein for checking the operation of the modulo multiplication 
circuits: 

m-l 

A= i: Ai R' 

m-\ 

B= 2 B^R^ 

r=0 
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m-\ 

N= S NiR' 

m-1 

Z= I Z,R 

m-1 m-1 

fiA>B) = (AB)/R'"+N S y; //?'"■' Z mod (i? - 7) = 2 Z, mod(^-;) 

m-1 

= AB + N S mod(i?-i) 

[m-1 m-1 
(2 ^modf7?-7)) (I 5. mod (7? - 7) ) + 
^ /=0 ;=0 

m-1 m-1 T 

( E A^, mod [R-])) ( S y; mod (R-1) J mod (i? - /) 

The hardware which calculates the function/^, B) is therefore checkable through the use of the 
following relationship (referred to below as Equation (1)): 

S Z, mod (i? - 7) = [ ( 2 ^, mod (i? - 7) ) ( 2 5, mod (7? - 7) ) + 

m-1 m-1 T 

(S iV,mod(7?-7)) (2 Fi mod (7? - 7) )] mod (7? - 7) (1) 

/=0 (=0 

The fortunate part of this checksum calculation is that it is computed on the fly. For example, the 

m-1 

circuitry necessary for the calculation of S Yi mod (7? - 7) is shown in Figure 24. It is noted, 

however, that the circuit(s) shown in Figure 24 are provided for the specific case of the use of the 
Chinese Remainder Theorem where Np and A^^ are known and the Processing Elements are split 
into two independent chains, one for calculating multiplication modulo Np and the other for 
calculating multiplication modulo A^^. In the case of modulo Np calculations, accumulating 
register 7 (reference numeral 652.3a; not to be confused with thej^/ variable used above to 
describe the algorithm) is initially set to zero with its output being used as an input to adder 
652.2a along with the input from the corresponding portion of register for the Processing 
Element partition which generates the values. The input from register 652. 1 a is added to the 
current Yp value to produce a running accumulation which is stored between cycles in register Y 
(reference numeral 652.3a). At the end of m cycles the contents of this register is the value 7'p = 

m-1 

Z Yi^p mod (7? - 7). Likewise, the corresponding circuit shown in the lower portion of Figure 24 

m-1 

operates in an identical fashion to compute Yg = S Yi,g mod (7? - 7). In the case of both the Yp 
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and the Y'q computations, adders 652.2a and 652.2b respectively are each k bit integer binary 
adders with carries out of the high order position being fed back as carry inputs to the low order 
positions. In this way addition modulo (R - 1) is carried out. 

Thus, the circuits shown in Figure 24 supply check sum values Yp and Y'q to check sum 
predictor circuit 800 of Figure 25. It is noted that circuits (not shown) very similar to those of 
Figure 24 are likewise provided for the generation of checksum values A p and A q from 
accumulated sums (modulo {R - 7)) of the values Ai,p and Ai,g respectively for / = 0, 7, . . . , m - 7. 
Similarly, checksum values Bp and Bp are generated from similar circuhs (also not shown) . 
Similar circuits also generate the values Np and N'q from the Ni,p and Ni,q values. Since these 
circuits are identical in structure and operation and differ only in the naming of the signal 
components, like the circuits mentioned just above they are also not shovm herein. 

The addition operation indicated in Equation (1) is carried out by adder 820 which 
performs addition modulo (7? - 7) and accordingly, like the other adders in the checksum system, 
includes a high order carry out signal output which is fed back as a low order carry input, as 
shown. Multiplexors 824, 825, 826, and 827 are operated under control of two signal lines. A 
first signal control line (p/q) controls multiplexors 824 and 826 to select between the two 
independent Processor Element chains for Np and A^^ processing. A second signal control line 
(Select Add) controls multiplexors 825 and 827 to effect the cumulative addition operation 
indicated by the summation from / = 0 to (/w - 7) in Equation (1). In order to calculate the 
intermediate checksum values ApBp and A 'q and 5 V a final addition operation is performed 
which adds together the contents of the Po and Pi registers (reference numerals 821 and 822, 
respectively) via operation of the Select Add control line. Adder 820 is also responsible for the 
final addition which generates (AByp and (ABYq by adding together the previous checksum 
values, stored in registers 831 and 832, with the cumulative checksums {NY)'p and iNY)'q. This 
results in the generation of the P Checksum and Q Checksum values from registers 831 and 832 
respectively. These signal lines are supplied to main checksum generation block 670 (in Figure 
23). In particular, the P Checksum and Q Checksum signal lines are supplied to comparators 
657a and 657b, respectively, as shown in Figure 26. 
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Accordingly, attention is now focused on the structure and operation of Figure 26. The 
main function of block 670 is the calculation of the left hand side of equation (1). As above, this 
circuit has two parts devoted to split calculations based on Np and Nq operations as when the 
Processor Elements in Figure 7 are split by controlling a middle Processing Element so as to 
5 force it into operating in the PEo mode. 

Each Processing Element chain (the Np chain or the Nq chain) outputs results of the 
modular multiplication operation 2k bits at a time. Accordingly, the circuit for generating the 
checksum value Z' for the Z variable is implemented as two adders with k bits each. 
Additionally, because of the splitting, there are actually a total of four adders shown in Figure 26. 
10 For the Np chain, for example, adder 656a, processes the high order bits output from the 

multiplication operation that produces each high order k bit output from the chain working on the 
' J modulo A^;, multiplication. After all of the 2k bit portions have been added together, multiplexor 

n 656a2 is operated to add together the sums in the high order register Z*p,H and the low order 

register Z^p,L, This resulting sum is compared with the P Checksum value by comparator 657a to 
produce an error indication Error2a, if there is no match. It is also noted that the adders in Figure 
i:-^ 26 all perform addition modulo {R- 1) and include a carry feedback out of the high order 

\ ^ position into the low order position. The bottom circuit shown in Figure 26 is structured and 

O operates in the same way as the upper circuits. However, as is clearly evident the bottom circuit 

i;3 is associated with and operates on signals generated during calculations modulo Nq based on the 

20 splitting of the Processor Element chain as described. Accordingly, the lower circuit in Figure 26 
generates the Zq checksum signal from the modulo Ng calculations, which resultant value is 
compared in comparator 657b to generate error signal Error2b, if there is no match. Thus, the 
output of block 670 is describable as: Error2a OR Error2b. Thus, at the end of each modular 
multiplication operation, an error signal is available which functions to provide an indication that 
25 all hardware elements have worked as designed to produce the intended result. 
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Additionally, Figure 23 also shows the inclusion of Auxiliary Computation circuit 653. 
This circuit is used to perform auxiliary operations such diS Z^J+K,Z = J'K and Z = J mod 
N, Checksum operations for these calculations are optional but preferable. The calculations 
carried out by Auxiliary Computation circuit 653 are relatively simple in comparison with the 
modular multiplication features. Residue checking for these calculations are also relatively 
simple. For the addition operation Z = J + A^, the checking mechanism is to make sure that the 
value of Z mod {R-1) is the same as the value of the modulo {R-1) sum of (J mod R-l) and {K 
mod i?-7), where is an even integer. Similarly, to check the operation of Z^J-K, one is to 
check if the value of Z mod {R-l) is the same as the value of the modulo (R-l) difference of (J 
mod R-l) and {K mod R-l), As for the operation of the modular reduction Z = J mod that is 
implemented by a long division, Z is the remainder of J divided by A'^. One has the expression J 
= QN+ Z, where Q is the quotient. The error checking for this modular reduction operation can 
be carried out by comparing the value of J mod (R-l) and the modulo sum of (Q mod (R-1))(N 
mod (R-l)) and (Zmod (R-l)), 

While many of the concepts presented above have been couched in terms of what are 
seemingly purely mathematical algorithms, the applications involved are really directed to the 
encryption, transmission and decryption of messages in whatever form these messages may be 
represented, as long as they are in digital form, or its equivalent (octal, binary coded decimal or 
hexadecimal). In these methods for encryption, transmission and decryption, messages are 
represented by large integers expressed in binary form so that for purposes explaining the theory, 
operation and value of the methods and devices presented herein, the description is necessarily of 
a mathematical nature. Nonetheless, the devices and methods describes herein provide practical 
methods for ensuring secure communications. As such the devices and methods described 
herein represent practical implementations of mathematical concepts. 

It is also noted that the operation of the circuits described herein are meant to occur over a 
repeated number of cycles. The description herein sets forth the ideal number of cycles generally 
required for proper operation in the most general situations. However, neither the specification 
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nor claims should be interpreted as being limited to the most general cases. In particular, it is 
noted that suboptimal control methods can sometimes lead to operation of the circuits for more 
cycles than is absolutely necessary, either by accident or by design. The scope of the claims 
herein should not be so narrowly construed as to forego this inclusion. Likewise, for certain 
5 input situations, the full number of cycles normally required for the most general cases is not 
required. Accordingly, some of the claims herein recite the operation for at most t cycles. 
Clearly, for its intended use in encryption and decryption, the circuits herein have been designed 
to handle the most general cases. The claims, however, should not be construed to be so narrow 
as to exclude either the simpler cases or the cases of deliberate operation overmore than the 
1 0 necessary number of cycles. 

Accordingly, from the above, it is seen that all of the objectives indicated are achieved by 
the circuits and processes described herein. In particular, it is seen that there is provided a circuit 
:f and process for carrying out multiplication of relatively large numbers modulo A'^ using either 

p multiplier and adder arrays or a plurality of nearly identical processing elements. It is also seen 

ni5 that these same circuits can be used not only to implement modular exponentiation but can also 
^^^^ be employed as part of hardware circuits for implementing solutions to problems based on the 

Chinese Remainder Theorem. It is even further noted that the objective of providing pipelined 
j T operations for a series of connected processing elements is achieved in a manner in which all of 

^ f the processing elements are functioning at all times to produce desired final or intermediate 

l'~z 

1:320 results. And it is also seen that circuits are provided for carrying out functions which are 

ancillary to the processes described above and, in particular, circuits and processes for producing 
negative multiplicative inverses. While such inverses are providable in a data processing system 
via software or by means of prior (and perhaps separate) computation, the processes and circuits 
shown herein are capable of providing this function in a short period of time with relatively 
25 simple hardware which takes advantage of already existing circuit registers and other elements. 

From the above, it is clear that the circuits shown in applicants' figures fulfill all of the 
objects indicated. Additionally, it is noted that the circuit is easy to construct and takes full 
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advantage of the parallelism brought about by structuring one of the operands in the 
multiplication process as w blocks of A: bits each. In particular,, it is seen that the circuit shown 
herein carries out a two-phase operation, one of which computes Xi and y^, with the second phase 
computing a value for Z which eventually, at the last step, becomes a desired result. In 
particular, it is seen that the circuit shown in applicants' figures provides a desired trade off 
between multipliers which have to be n bits by n bits in size and between serial circuits which 
operate with only one bit of a factor being considered at each step. 

While the invention has been described in detail herein in accordance with certain preferred 
embodiments thereof, many modifications and changes therein may be effected by those skilled 
in the art. Accordingly, it is intended by the appended claims to cover all such modifications and 
changes as fall within the true spirit and scope of the invention. 
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